• C#操作MySQL的类


    C#操作MySQL的类

    public class MySqlService
        {
            private static log4net.ILog logger = log4net.LogManager.GetLogger(typeof(MySqlService));
    
            //server=localhost;user id=root;password=root;persist security info=True;database=test
            //Data Source=127.0.0.1;port=3306;Initial Catalog=tsyw;user id=root;password=q2ii3sfc;Charset=gbk
            private string conn_str = "server=localhost;user id=root;password=q2ii3sfc;persist security info=True;database=win008";
    
            public MySqlService()
            {
    
            }
            /// <summary>
            /// 构造函数
            /// </summary>
            /// <param name="conn_str"></param>
            public MySqlService(string conn_str)
            {
                this.conn_str = conn_str;
            }
    
            /// <summary>
            /// 执行sql语句返回List-Hashtable数据集
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            public List<Hashtable> Select(string sql)
            {
                List<Hashtable> lst = new List<Hashtable>();
                using (MySqlConnection connection = new MySqlConnection(this.conn_str))
                {
                    try
                    {
                        connection.Open();
                        MySqlCommand cmd = new MySqlCommand(sql, connection);
                        MySqlDataReader mdr = cmd.ExecuteReader();
                        int columnCount = mdr.FieldCount;
                        string _key = string.Empty;
                        while (mdr.Read())
                        {
                            Hashtable ht = new Hashtable();
                            for(int i = 0; i < columnCount; i++)
                            {
                                _key = mdr.GetName(i);
                                ht[_key] = mdr[i];
                            }
    
                            lst.Add(ht);
                        }
                        mdr.Close();
                        connection.Close();
                    }
                    catch (Exception ex)
                    {
                        logger.Warn("执行操作语句异常, SQL:" + sql, ex);
                    }
                }
                return lst;
            }
            /// <summary>
            /// 
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            public System.Data.DataSet Query(string sql)
            {
                return null;
            }
    
            /// <summary>
            /// 执行操作语句 delete/insert/update
            /// <para>返回影响行数</para>
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            public int Execute(string sql)
            {
                int rest = 0;
                using (MySqlConnection connection = new MySqlConnection(this.conn_str))
                {
                    try
                    {
                        connection.Open();
                        MySqlCommand cmd = new MySqlCommand(sql, connection);
                        rest = cmd.ExecuteNonQuery();
                        rest = (int)(cmd.LastInsertedId>0?cmd.LastInsertedId:rest);
    
                        connection.Close();
                    }
                    catch (Exception ex)
                    {
                        logger.Warn("执行操作语句异常, SQL:" + sql, ex);
                    }
                }
    
                return rest;
            }
    
            public Hashtable FetchRow(string sql)
            {
                Hashtable ht = new Hashtable();
                using (MySqlConnection connection = new MySqlConnection(this.conn_str))
                {
                    try
                    {
                        connection.Open();
                        MySqlCommand cmd = new MySqlCommand(sql, connection);
                        MySqlDataReader mdr = cmd.ExecuteReader();
                        int columnCount = mdr.FieldCount;
                        string _key = string.Empty;
                        while (mdr.Read())
                        {
                            for (int i = 0; i < columnCount; i++)
                            {
                                _key = mdr.GetName(i);
                                ht[_key] = mdr[i];
                            }
                            break;
                        }
                        mdr.Close();
                        connection.Close();
                    }
                    catch (Exception ex)
                    {
                        logger.Warn("执行操作语句异常, SQL:" + sql, ex);
                    }
                }
                return ht;
            }
    
            /// <summary>
            /// 获取语句第一行第一列数据
            /// </summary>
            /// <param name="sql"></param>
            /// <returns></returns>
            public T FetchFirst<T>(string sql) {
                T t;
                using (MySqlConnection connection = new MySqlConnection(this.conn_str))
                {
                    try
                    {
                        connection.Open();
                        MySqlCommand cmd = new MySqlCommand(sql, connection);
                        t = (T)cmd.ExecuteScalar();
                        connection.Close();
                    }
                    catch (Exception ex)
                    {
                        t = default(T);
                        logger.Warn("执行操作语句异常, SQL:" + sql, ex);
                    }
                }
                return t;
            }
    
            /// <summary>
            /// 检查链接是否OK
            /// </summary>
            /// <returns></returns>
            public bool Ping()
            {
                bool rest = false;
                using (MySqlConnection connection = new MySqlConnection(this.conn_str))
                {
                    try
                    {
                        connection.Open();
                        MySqlCommand cmd = new MySqlCommand("select 1", connection);
                        cmd.ExecuteScalar();
                        connection.Close();
                        rest = true;
                    }
                    catch
                    {
                        rest = false;
                    }
                }
    
                return rest;
            }
    
        }
    
    C#操作MySQL的类
    [C#cāozuò MySQL de lèi]
    C# operation MySQL class
  • 相关阅读:
    LeetCode485 最大连续1的个数
    LeetCode167 两数之和 II
    js浮点数类型
    js整数类型
    js布尔类型
    js重复赋值 js数据交换 js调式方法
    JavaScript变量
    数据类型分类
    重复赋值 数据交换 查看程序执行结果
    JS注释 JS变量
  • 原文地址:https://www.cnblogs.com/equation/p/10625391.html
Copyright © 2020-2023  润新知