當前位置: 首頁>>代碼示例>>C#>>正文


C# MySqlConnection.Connected方法代碼示例

本文整理匯總了C#中MySql.Data.MySqlClient.MySqlConnection.Connected方法的典型用法代碼示例。如果您正苦於以下問題:C# MySqlConnection.Connected方法的具體用法?C# MySqlConnection.Connected怎麽用?C# MySqlConnection.Connected使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在MySql.Data.MySqlClient.MySqlConnection的用法示例。


在下文中一共展示了MySqlConnection.Connected方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Main

        public static void Main()
        {
            Console.Title = "Table Comparator V 2.0";

            MySqlConnection connection = new MySqlConnection(Settings.Default.ConnectionString);
            if (!connection.Connected())
                return;

            Console.WriteLine("-================================== Welcome ==================================-");
            Console.WriteLine("==========||========================================================||=======||");
            Console.WriteLine("Statistics|| Total:  || Bad fields:  || Table:                      || %     ||");
            Console.WriteLine("==========||========================================================||=======||");

            DirectoryInfo info = new DirectoryInfo("tables");
            FileInfo[] structures = info.GetFiles("*.xml", SearchOption.TopDirectoryOnly);
            foreach (FileInfo document in structures)
            {
                XmlSerializer serializer = new XmlSerializer(typeof(Table));
                Table table = (Table)serializer.Deserialize(document.OpenRead());

                string key = table.Fields[0];
                string prefix = table.Prefix;
                string tableName = table.TableName;

                StringBuilder cmdText = new StringBuilder(1024);
                {
                    cmdText.Append("SELECT ");

                    foreach (string field in table.Fields)
                        cmdText.AppendFormat("{0}.{1}, ", tableName, field);

                    foreach (string field in table.Fields)
                        cmdText.AppendFormat("{0}_{1}.{2}, ", tableName, prefix, field);

                    cmdText.AppendFormat("FROM {0} INNER JOIN {0}_sniff ON {0}.{1} = {0}_sniff.{1} ORDER BY {0}.{1};", tableName, key).AppendLine().Replace(", FROM", " FROM");
                }
                List<List<object>> normalDataTemplates = new List<List<object>>(UInt16.MaxValue);
                List<List<object>> sniffedDataTemplates = new List<List<object>>(UInt16.MaxValue);

                try
                {
                    using (MySqlCommand command = new MySqlCommand(cmdText.ToString(), connection))
                    using (MySqlDataReader reader = command.ExecuteReader())
                    {
                        int count = reader.FieldCount / 2;
                        while (reader.Read())
                        {
                            List<object> normalTemplate = new List<object>(count);
                            List<object> sniffTemplate = new List<object>(count);

                            for (int i = 0; i < count; ++i)
                                normalTemplate.Add(reader[i]);

                            for (int i = count; i < (count * 2); ++i)
                                sniffTemplate.Add(reader[i]);

                            normalDataTemplates.Add(normalTemplate);
                            sniffedDataTemplates.Add(sniffTemplate);
                        }
                    }
                }
                catch (Exception e)
                {
                    Console.WriteLine("ERROR: {0}", e.Message);
                    continue;
                }

                int badFieldCount = 0;
                StringBuilder content = new StringBuilder(UInt16.MaxValue);
                for (int i = 0; i < normalDataTemplates.Count; ++i)
                {
                    bool error = false;
                    StringBuilder contentInternal = new StringBuilder();
                    List<object> normalTemplate = normalDataTemplates[i];
                    List<object> sniffTemplate = sniffedDataTemplates[i];

                    object entry = normalTemplate[0];
                    if (!entry.Equals(sniffTemplate[0]))
                        continue;

                    contentInternal.AppendFormat("UPDATE `{0}` SET ", tableName);
                    for (int j = 1; j < normalTemplate.Count; ++j)
                    {
                        if (normalTemplate[j].Equals(sniffTemplate[j]))
                            continue;

                        contentInternal.AppendFormat(NumberFormatInfo.InvariantInfo, "`{0}` = '{1}', ", table.Fields[j], sniffTemplate[j]);
                        error = true;
                    }
                    contentInternal.Remove(contentInternal.Length - 2, 2);
                    contentInternal.AppendFormat(" WHERE `{0}` = {1};", key, entry).AppendLine();

                    if (!error)
                        continue;

                    content.Append(contentInternal);
                    ++badFieldCount;
                }

                if (badFieldCount > 0)
//.........這裏部分代碼省略.........
開發者ID:Lordron,項目名稱:TableComparator-v-2.0,代碼行數:101,代碼來源:Program.cs


注:本文中的MySql.Data.MySqlClient.MySqlConnection.Connected方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。