主要封装为MySqlHelper类
namespace CiWong.LearningLevelApi.MySqlHelp
{
///
/// MySqlHelper 类是基于.net框架开发的数据库操作类
///
public class MySqlHelper
{
#region 缓存Hashtable
// 存储缓存参数的Hashtable
private static Hashtable parmCache = Hashtable.Synchronized(new Hashtable());
#endregion
#region 重载+1 获取连接字符串
///
/// 重载+1 获取连接字符串 [GetStrCon()]
///
/// 连接字符串(如果配置文件中无[SQL]名称的连接字符串,则抛出异常)
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 获取连接字符串
///
/// 重载+2 获取连接字符串 [GetStrCon(string strConfig)]
/// 如果配置文件中有strConfig为名称的连接字符串,则
/// 获取它的内容
/// 如果没有,则默认strConfig为连接字符串
///
/// 配置文件中连接字符串的名称
/// 连接字符串
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()]
///
/// 重载+1 返回 conn连接对象 [GetConn()]
///
/// MySqlConnection
public static MySqlConnection GetConn()
{
try
{
return new MySqlConnection(GetStrCon());
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
throw;
}
}
#endregion
#region 重载+2 创建连接对象 [GetConn()]
///
/// 重载+2 返回 conn连接对象 [GetConn()]
/// 如果配置文件中有strConfig名称的连拉字符串,则
/// 获取它的内容
/// 如果没有,则默认strConfig为连接字符串
///
/// 配置文件中连接字符串的名称
/// MySqlConnection
public static MySqlConnection GetConn(string strConfig)
{
try
{
return new MySqlConnection(GetStrCon(strConfig));
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
throw;
}
}
#endregion
#region 关闭连接[CloseConn(...)]
///
/// 关闭 conn连接对象
///
/// 连接对象
public static void CloseConn(MySqlConnection conn)
{
if (conn.State != ConnectionState.Closed)
conn.Close();
}
#endregion
#region 清空与指定连接相关的连接池
///
/// 清空与指定连接相关的连接池 [ClosePool(MySqlConnection conn)]
///
public static void ClosePool(MySqlConnection conn)
{
MySqlConnection.ClearPool(conn);
}
#endregion
#region 清空所有连接池
///
/// 清空所有连接池 [ClosePool()]
///
public static void ClosePool()
{
MySqlConnection.ClearAllPools();
}
#endregion
#region 返回MySqlCommand对象[GetCmd(...)]
///
/// 返回MySqlCommand对象
///
/// conn 连接对象
/// 事物对象
/// SQL 执行的类型
/// SQL 执行语句
/// MySqlParameter[] 对象
/// 返回comm 对象
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(...)]
///
/// 重载+1 通过连接字符串,执行SqlCommand(不返回结果集)
/// 利用提供的参数值
///
///
/// e.g.:
/// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 为MySqlConnection对象提供:一个有效的连接字符串
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 执行命令受影响的记录条数
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(...)]
///
/// 重载+2 通过存在的MySqlConnection对象,执行MySqlCommand(不返回结果集)
/// 利用提供的参数值
///
///
/// e.g.:
/// int result = ExecuteNonQuery(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 一个已经存在的SqlConnection对象
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 执行命令受影响的记录条数
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(...)]
///
/// 重载+3 通过存在的 MySqlTransaction,执行MySqlCommand(不返回结果集)
/// 利用提供的参数值
///
///
/// e.g.:
/// int result = ExecuteNonQuery(trans, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 一个已经存在的 trans
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 执行命令受影响的记录条数
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(...)]
///
/// 重载+1 通过连接字符串,执行MySqlCommand(返回结果集)
/// 利用提供的参数值
///
///
/// e.g.:
/// DataSet ds = ExecuteDataSet(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 为MySqlConnection对象提供:一个有效的连接字符串
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 返回一个结果集:DataSet对象
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(...)]
///
/// 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回结果集)
/// 利用提供的参数值
///
///
/// e.g.:
/// DataSet ds = ExecuteDataSet(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 一个已经存在的MySqlConnection对象
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 返回一个结果集:DataSet对象
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(...)]
///
/// 重载+1 通过连接字符串,执行MySqlCommand(返回结果集的一个MySqlDataReader对象)
/// 利用提供的参数值
///
///
/// e.g.:
/// MySqlDataReader r = ExecuteReader(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 为MySqlConnection对象提供:一个有效的连接字符串
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 包含结果集的一个:MySqlDataReader对象
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(...)]
///
/// 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回结果集的一个MySqlDataReader对象)
/// 利用提供的参数值
///
///
/// e.g.:
/// MySqlDataReader r = ExecuteReader(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 一个已经存在的SqlConnection对象
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 包含结果集的一个:MySqlDataReader对象
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(...)]
///
/// 重载+1 通过连接字符串,执行MySqlCommand(返回第一条记录的第一列的值,一般是返回汇总值等;如:select max(id) from userTab)
/// 利用提供的参数值
///
///
/// e.g.:
/// Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 为MySqlConnection对象提供:一个有效的连接字符串
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 返回一个对象:如果要使用具体的值,需要使用Convert.To{Type}进行转换
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(...)]
///
/// 重载+2 通过已经存在的MySqlConnection对象,执行MySqlCommand(返回第一条记录的第一列的值,一般是返回汇总值等;如:Select max(ColumnName) From TableName)
/// 利用提供的参数值
///
///
/// e.g.:
/// Object obj = ExecuteScalar(conn, CommandType.StoredProcedure, "PublishOrders", new MySqlParameter("@prodid", 24));
///
/// 一个已经存在的SqlConnection对象
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本
/// 执行命令的参数列表
/// 返回一个对象:如果要使用具体的值,需要使用Convert.To{Type}进行转换
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(...)]
///
/// 存储:将参数数组增加至缓冲区
///
/// 缓冲区参数的键名
/// 缓冲区对应键名的参数值
public static void CacheParameters(string cacheKey, params MySqlParameter[] cmdParms)
{
parmCache[cacheKey] = cmdParms;
}
#endregion
#region 从缓冲区得到Hashtable中的参数列表的值 [GetCachedParameters(...)]
///
/// 检索值:得到缓冲区中的参数列表值
///
/// 缓冲区参数的键名
/// 缓冲区对应键名的参数值
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(...)]
///
/// 要执行:预定义Command对象(PrepareCommand)
///
/// MySqlCommand 对象
/// MySqlConnection 对象
/// MySqlTransaction 对象
/// 命令类别:存储过程、文本字符串等
/// 存储过程名称或SQL命令文本,如:select * from UserTab
/// Command对象需要使用的参数列表
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(...)]
///
/// 提交事务
///
/// 事务
public static void TransactionCommit(MySqlTransaction trans)
{
trans.Commit();
}
#endregion
#region 回滚事务 [TransactionRollback(...)]
///
/// 回滚事务
///
/// 事务
public static void TransactionRollback(MySqlTransaction trans)
{
trans.Rollback();
}
#endregion
}
}