zoukankan      html  css  js  c++  java
  • MySql数据库连接操作

    主要封装为MySqlHelper类

    namespace CiWong.LearningLevelApi.MySqlHelp
    {
        /// <summary>
        /// MySqlHelper 类是基于.net框架开发的数据库操作类
        /// </summary>
        public class MySqlHelper
        {
            #region 缓存Hashtable
            // 存储缓存参数的Hashtable
            private static Hashtable parmCache = Hashtable.Synchronized(new Hashtable());
            #endregion
    
            #region 重载+1 获取连接字符串
            /// <summary>
            /// 重载+1 获取连接字符串 [GetStrCon()]
            /// </summary>
            /// <returns>连接字符串(如果配置文件中无[SQL]名称的连接字符串,则抛出异常)</returns>
            public static string GetStrCon()
            {
                try
                {
                    string CONN_STRING = ConfigurationManager.ConnectionStrings["QuesContext"].ConnectionString;
                    return CONN_STRING;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(string.Format("配置文件中没有[SQL]名称的connectionStrings!错误原因:{0}", ex.ToString()));
                    throw;
                }
            }
            #endregion
    
            #region 重载+2 获取连接字符串
            /// <summary>
            /// 重载+2 获取连接字符串 [GetStrCon(string strConfig)]
            ///     如果配置文件中有strConfig为名称的连接字符串,则
            ///         获取它的内容
            ///     如果没有,则默认strConfig为连接字符串
            /// </summary>
            /// <param name="strConfig">配置文件中连接字符串的名称</param>
            /// <returns>连接字符串</returns>
            public static string GetStrCon(string strConfig)
            {
                string CONN_STRING = string.Empty;
                if (ConfigurationManager.ConnectionStrings[strConfig] != null)
                    CONN_STRING = ConfigurationManager.ConnectionStrings[strConfig].ConnectionString;
                else
                    CONN_STRING = strConfig;
                return CONN_STRING;
            }
            #endregion
    
            #region 重载+1 创建连接对象 [GetConn()]
            /// <summary>
            /// 重载+1 返回 conn连接对象 [GetConn()]
            /// </summary>
            /// <returns> MySqlConnection </returns>
            public static MySqlConnection GetConn()
            {
                try
                {
                    return new MySqlConnection(GetStrCon());
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+2 创建连接对象 [GetConn()]
            /// <summary>
            /// 重载+2 返回 conn连接对象 [GetConn()]
            ///     如果配置文件中有strConfig名称的连拉字符串,则
            ///         获取它的内容
            ///     如果没有,则默认strConfig为连接字符串
            /// </summary>
            /// <param name="strConfig">配置文件中连接字符串的名称</param>
            /// <returns> MySqlConnection </returns>
            public static MySqlConnection GetConn(string strConfig)
            {
                try
                {
                    return new MySqlConnection(GetStrCon(strConfig));
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 关闭连接[CloseConn(...)]
            /// <summary>
            /// 关闭 conn连接对象
            /// </summary>
            /// <param name="conn">连接对象</param>
            public static void CloseConn(MySqlConnection conn)
            {
                if (conn.State != ConnectionState.Closed)
                    conn.Close();
            }
            #endregion
    
            #region 清空与指定连接相关的连接池
            /// <summary>
            /// 清空与指定连接相关的连接池 [ClosePool(MySqlConnection conn)]
            /// </summary>
            public static void ClosePool(MySqlConnection conn)
            {
                MySqlConnection.ClearPool(conn);
            }
            #endregion
    
            #region 清空所有连接池
            /// <summary>
            /// 清空所有连接池 [ClosePool()]
            /// </summary>
            public static void ClosePool()
            {
                MySqlConnection.ClearAllPools();
            }
            #endregion
    
            #region 返回MySqlCommand对象[GetCmd(...)]
            /// <summary>
            /// 返回MySqlCommand对象
            /// </summary>
            /// <param name="conn">conn 连接对象</param>
            /// <param name="trans">事物对象</param>
            /// <param name="cmdType">SQL 执行的类型</param>
            /// <param name="cmdText">SQL	执行语句</param>
            /// <param name="cmdParms">MySqlParameter[] 对象</param>
            /// <returns> 返回comm 对象</returns>
            public static MySqlCommand GetCmd(MySqlConnection conn, MySqlTransaction trans, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                try
                {
                    if (conn.State != ConnectionState.Open)
                        conn.Open();
    
                    MySqlCommand cmd = new MySqlCommand();
                    cmd.Connection = conn;
                    cmd.CommandType = cmdType;
                    cmd.CommandText = cmdText;
    
                    if (trans != null)
                        cmd.Transaction = trans;
    
                    if (cmdParms != null)
                    {
                        foreach (MySqlParameter parm in cmdParms)
                            cmd.Parameters.Add(parm);
                    }
    
                    return cmd;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+1 通过连接字符串,执行SqlCommand(不返回结果集)[ExecuteNonQuery(...)]
            /// <summary>
            /// 重载+1 通过连接字符串,执行SqlCommand(不返回结果集)
            /// 利用提供的参数值		
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="connString">为MySqlConnection对象提供:一个有效的连接字符串</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>
            /// <returns>执行命令受影响的记录条数</returns>
            public static int ExecuteNonQuery(string connString, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
    
                    using (MySqlConnection conn = new MySqlConnection(connString))
                    {
                        PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                        int val = cmd.ExecuteNonQuery();
                        cmd.Parameters.Clear();
                        cmd.Dispose();
                        return val;
                    }
                }
                catch (Exception ex)
                {
                    //引发异常,没有记录受影响
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+2 通过存在的MySqlConnection对象,执行MySqlCommand(不返回结果集)[ExecuteNonQuery(...)]
            /// <summary>
            /// 重载+2 通过存在的MySqlConnection对象,执行MySqlCommand(不返回结果集)
            /// 利用提供的参数值	
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  int result = ExecuteNonQuery(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="conn">一个已经存在的SqlConnection对象</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>
            /// <returns>执行命令受影响的记录条数</returns>
            public static int ExecuteNonQuery(MySqlConnection conn, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
    
                    PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                    int val = cmd.ExecuteNonQuery();
                    cmd.Parameters.Clear();
                    cmd.Dispose();
                    return val;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    //引发异常,没有记录受影响
                    throw;
                }
                finally
                {
                    conn.Close();
                }
            }
            #endregion
    
            #region 重载+3  通过存在的 MySqlTransaction,执行MySqlCommand(不返回结果集)[ExecuteNonQuery(...)]
            /// <summary>
            /// 重载+3  通过存在的 MySqlTransaction,执行MySqlCommand(不返回结果集)
            /// 利用提供的参数值		
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  int result = ExecuteNonQuery(trans, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>		
            /// <param name="trans">一个已经存在的 trans</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>
            /// <returns>执行命令受影响的记录条数</returns>
            public static int ExecuteNonQuery(MySqlTransaction trans, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
    
                    PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, cmdParms);
                    int val = cmd.ExecuteNonQuery();
                    cmd.Parameters.Clear();
                    cmd.Dispose();
                    return val;
                }
                catch (Exception ex)
                {
                    //引发异常,没有记录受影响
                    Console.WriteLine(ex.ToString());
                    throw;
                }
                finally
                {
                    trans.Connection.Close();
                }
            }
            #endregion
    
            #region 重载+1 通过连接字符串,执行MySqlCommand(返回结果集)  [ExecuteDataSet(...)]
            /// <summary>
            /// 重载+1 通过连接字符串,执行MySqlCommand(返回结果集)
            /// 利用提供的参数值		
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  DataSet ds = ExecuteDataSet(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="connString">为MySqlConnection对象提供:一个有效的连接字符串</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>
            /// <returns>返回一个结果集:DataSet对象</returns>
            public static DataSet ExecuteDataSet(string connString, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                DataSet ds = new DataSet();
                //使用一个异常,如果发生异常,则将连接关闭	
                try
                {
                    using (MySqlConnection conn = new MySqlConnection(connString))
                    {
                        MySqlCommand cmd = new MySqlCommand();
                        PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                        MySqlDataAdapter adp = new MySqlDataAdapter(cmd);
                        adp.Fill(ds);
                        cmd.Parameters.Clear();
                        cmd.Dispose();
                        return ds;
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回结果集)  [ExecuteDataSet(...)]
            /// <summary>
            /// 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回结果集)
            /// 利用提供的参数值		
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  DataSet ds = ExecuteDataSet(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="conn">一个已经存在的MySqlConnection对象</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>
            /// <returns>返回一个结果集:DataSet对象</returns>
            public static DataSet ExecuteDataSet(MySqlConnection conn, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                DataSet ds = new DataSet();
                //使用一个异常,如果发生异常,则将连接关闭	
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
                    PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                    MySqlDataAdapter adp = new MySqlDataAdapter(cmd);
                    adp.Fill(ds);
                    cmd.Parameters.Clear();
                    cmd.Dispose();
                    return ds;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
                finally
                {
                    conn.Close();
                }
            }
            #endregion
    
            #region 重载+1 通过连接字符串,执行MySqlCommand(返回结果集的一个MySqlDataReader对象)[ExecuteReader(...)]
            /// <summary>
            /// 重载+1 通过连接字符串,执行MySqlCommand(返回结果集的一个MySqlDataReader对象)
            /// 利用提供的参数值		
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  MySqlDataReader r = ExecuteReader(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="connString">为MySqlConnection对象提供:一个有效的连接字符串</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>	
            /// <returns>包含结果集的一个:MySqlDataReader对象</returns>
            public static MySqlDataReader ExecuteReader(string connString, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                MySqlConnection conn = new MySqlConnection(connString);
    
                //使用一个异常,如果发生异常,则将连接关闭			
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
                    PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                    MySqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
                    cmd.Parameters.Clear();
                    cmd.Dispose();
                    return rdr;
                }
                catch (Exception ex)
                {
                    CloseConn(conn);
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回结果集的一个MySqlDataReader对象) [ExecuteReader(...)]
            /// <summary>
            /// 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回结果集的一个MySqlDataReader对象)
            /// 利用提供的参数值		
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  MySqlDataReader r = ExecuteReader(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="conn">一个已经存在的SqlConnection对象</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>			
            /// <returns>包含结果集的一个:MySqlDataReader对象</returns>
            public static MySqlDataReader ExecuteReader(MySqlConnection conn, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                //使用一个异常,如果发生异常,则将连接关闭	
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
                    PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                    MySqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
                    cmd.Parameters.Clear();
                    cmd.Dispose();
                    return rdr;
                }
                catch (Exception ex)
                {
                    CloseConn(conn);
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+1 通过连接字符串,执行MySqlCommand [ExecuteScalar(...)]
            /// <summary>
            /// 重载+1 通过连接字符串,执行MySqlCommand(返回第一条记录的第一列的值,一般是返回汇总值等;如:select max(id) from userTab)
            /// 利用提供的参数值				
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="connString">为MySqlConnection对象提供:一个有效的连接字符串</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>	
            /// <returns>返回一个对象:如果要使用具体的值,需要使用Convert.To{Type}进行转换</returns>
            public static object ExecuteScalar(string connString, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
    
                    using (MySqlConnection conn = new MySqlConnection(connString))
                    {
                        PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                        object val = cmd.ExecuteScalar();
                        cmd.Parameters.Clear();
                        cmd.Dispose();
                        return val;
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand [ExecuteScalar(...)]
            /// <summary>
            /// 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回第一条记录的第一列的值,一般是返回汇总值等;如:Select max(ColumnName) From TableName)
            /// 利用提供的参数值	
            /// </summary>
            /// <remarks>
            /// e.g.:  
            ///  Object obj = ExecuteScalar(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
            /// </remarks>
            /// <param name="conn">一个已经存在的SqlConnection对象</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本</param>
            /// <param name="cmdParms">执行命令的参数列表</param>
            /// <returns>返回一个对象:如果要使用具体的值,需要使用Convert.To{Type}进行转换</returns>
            public static object ExecuteScalar(MySqlConnection conn, CommandType cmdType, string cmdText, params MySqlParameter[] cmdParms)
            {
                try
                {
                    MySqlCommand cmd = new MySqlCommand();
    
                    PrepareCommand(cmd, conn, null, cmdType, cmdText, cmdParms);
                    object val = cmd.ExecuteScalar();
                    cmd.Parameters.Clear();
                    cmd.Dispose();
                    return val;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
                finally
                {
                    CloseConn(conn);
                }
            }
            #endregion
    
            #region 将参数数组增加至Hashtable,缓存在缓冲区 [CacheParameters(...)]
            /// <summary>
            /// 存储:将参数数组增加至缓冲区		
            /// </summary>
            /// <param name="cacheKey">缓冲区参数的键名</param>
            /// <param name="cmdParms">缓冲区对应键名的参数值</param>
            public static void CacheParameters(string cacheKey, params MySqlParameter[] cmdParms)
            {
                parmCache[cacheKey] = cmdParms;
            }
            #endregion
    
            #region 从缓冲区得到Hashtable中的参数列表的值 [GetCachedParameters(...)]
            /// <summary>
            /// 检索值:得到缓冲区中的参数列表值
            /// </summary>
            /// <param name="cacheKey">缓冲区参数的键名</param>
            /// <returns>缓冲区对应键名的参数值</returns>
            public static MySqlParameter[] GetCachedParameters(string cacheKey)
            {
                //获取 key 为cachekey 的值 parmCache[参数化SQL语句]=parameter[]数据组对象
                MySqlParameter[] cachedParms = (MySqlParameter[])parmCache[cacheKey];
    
                //如果不存在 则返回为空
                if (cachedParms == null)
                    return null;
                //反之 Hashtable表中存在 key为cacheky 的对象则返回 他的 副本 对象 par[]
                MySqlParameter[] clonedParms = new MySqlParameter[cachedParms.Length];
    
                for (int i = 0, j = cachedParms.Length; i < j; i++)
                    clonedParms[i] = (MySqlParameter)((ICloneable)cachedParms[i]).Clone();
    
                return clonedParms;
            }
            #endregion
    
            #region 执行预定义Command对象[PrepareCommand(...)]
            /// <summary>
            /// 要执行:预定义Command对象(PrepareCommand)
            /// </summary>
            /// <param name="cmd">MySqlCommand 对象</param>
            /// <param name="conn">MySqlConnection 对象</param>
            /// <param name="trans">MySqlTransaction 对象</param>
            /// <param name="cmdType">命令类别:存储过程、文本字符串等</param>
            /// <param name="cmdText">存储过程名称或SQL命令文本,如:select * from UserTab</param>		
            /// <param name="cmdParms">Command对象需要使用的参数列表</param>
            public static void PrepareCommand(MySqlCommand cmd, MySqlConnection conn, MySqlTransaction trans, CommandType cmdType, string cmdText, MySqlParameter[] cmdParms)
            {
                try
                {
                    if (conn.State != ConnectionState.Open)
                        conn.Open();
    
                    cmd.Connection = conn;
                    cmd.CommandText = cmdText;
    
                    if (trans != null)
                        cmd.Transaction = trans;
    
                    cmd.CommandType = cmdType;
    
                    if (cmdParms != null)
                    {
                        foreach (MySqlParameter parm in cmdParms)
                            cmd.Parameters.Add(parm);
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.ToString());
                    throw;
                }
            }
            #endregion
    
            #region 提交事务 [TransactionCommit(...)]
            /// <summary>
            /// 提交事务
            /// </summary>
            /// <param name="trans">事务</param>
            public static void TransactionCommit(MySqlTransaction trans)
            {
                trans.Commit();
            }
            #endregion
    
            #region 回滚事务 [TransactionRollback(...)]
            /// <summary>
            /// 回滚事务
            /// </summary>
            /// <param name="trans">事务</param>
            public static void TransactionRollback(MySqlTransaction trans)
            {
                trans.Rollback();
            }
            #endregion
        }
    }
    

      

  • 相关阅读:
    2-5-归并链式存储的单链表-线性表-第2章-《数据结构》课本源码-严蔚敏吴伟民版
    2-4-单链表链式存储结构-线性表-第2章-《数据结构》课本源码-严蔚敏吴伟民版
    2-3-归并单链表(顺序表)-线性表-第2章-《数据结构》课本源码-严蔚敏吴伟民版
    2-2-求并集A=A∪B-线性表-第2章-《数据结构》课本源码-严蔚敏吴伟民版
    2-1-单链表顺序存储结构-线性表-第2章-《数据结构》课本源码-严蔚敏吴伟民版
    线性表-第2章-《数据结构题集》习题解析-严蔚敏吴伟民版
    绪论-第1章-《数据结构题集》习题解析-严蔚敏吴伟民版
    1-1-绪论-第1章-《数据结构》课本源码-严蔚敏吴伟民版
    【十大经典数据挖掘算法】PageRank
    灵活可扩展的工作流管理平台Airflow
  • 原文地址:https://www.cnblogs.com/Aamir-Ye/p/4680777.html
Copyright © 2011-2022 走看看