第一步:编写AdoHelper类,用于封装对数据库的操作,能同时支持多个数据库(目前支持SqlServer、Oracle、Access),可扩展支持任何类型的数据库。
下面先进行代码片段分析,分析完毕后将贴出完整代码,代码块1-1:
using System; using System.Collections; using System.Collections.Generic; using System.Configuration; using System.Text; using System.Data; using System.Data.Common; using System.Data.SqlClient; using System.Data.OracleClient; using System.Orm.Common; namespace System.Orm.DBUtility { public class AdoHelper { //获取数据库类型 private static string strDbType = CommonUtils.GetConfigValueByKey("dbType").ToUpper(); //将数据库类型转换成枚举类型 public static DatabaseType DbType = DatabaseTypeEnumParse<DatabaseType>(strDbType);
//获取数据库连接字符串 public static string ConnectionString = GetConnectionString("connectionString"); //获取数据库命名参数符号,比如@(SQLSERVER)、:(ORACLE) public static string DbParmChar = DbFactory.CreateDbParmCharacter();
(剖析Step1 Begin)==================================================
代码块1-1中private static string strDbType = CommonUtils.GetConfigValueByKey("dbType").ToUpper();使用到了CommonUtils.GetConfigValueByKey方法,通过读取传入的dbType字符串,到web.config配置文件中取出所配置的数据库类型,配置文件代码块1-2:
<?xml version="1.0"?> <configuration> <appSettings> <add key="dbType" value="oracle"/> <add key="connectionString" value="DataSource=test;UserID=test;Password=123"/> </appSettings> <system.web> <compilation debug="true"> </compilation> <authentication mode="Windows"/> </system.web> </configuration>
下面是CommonUtils.GetConfigValueByKey方法的实现代码块1-3:
using System; using System.Collections.Generic; using System.Text; using System.Configuration; using System.Reflection; namespace System.Orm.Common { public class CommonUtils { // <summary> // 根据传入的Key获取配置文件中的Value值 // </summary> // <param name="Key"></param> // <returns></returns> public static string GetConfigValueByKey(string Key) { try { return ConfigurationManager.AppSettings[Key].ToString(); } catch { throw new Exception("web.config中 Key=\"" + Key + "\"未配置或配置错误!"); } }
(剖析Step1 End)==================================================
(剖析Step2 Begin)==================================================
代码块1-1中public static DatabaseType DbType = DatabaseTypeEnumParse<DatabaseType>(strDbType);
这段代码是将在配置文件中取到的数据库类型字符串(比如:oracle)转换成已经定义的枚举类型,这里转换为DatabaseType枚举,DatabaseType代码块1-4:
using System; using System.Collections.Generic; using System.Text; namespace System.Orm.DBUtility { // <summary> // 数据库类型枚举,需要扩展类型可在此添加 // </summary> public enum DatabaseType { SQLSERVER, ORACLE, ACCESS, MYSQL } }
然后分析如何将字符串转换成枚举类型,用到DatabaseTypeEnumParse这个方法,代码块1-5:
// <summary> // 用于数据库类型的字符串枚举转换 // </summary> // <typeparam name="T"></typeparam> // <param name="value"></param> // <returns></returns> public static T DatabaseTypeEnumParse<T>(string value) { try { return CommonUtils.EnumParse<T>(value); } catch { throw new Exception("数据库类型\"" + value + "\"错误,请检查!"); } }
这里实现枚举转换的功能来自CommonUtils.EnumParse<T>(value);代码块1-6:
// <summary> // 用于字符串和枚举类型的转换 // </summary> // <typeparam name="T"></typeparam> // <param name="value"></param> // <returns></returns> public static T EnumParse<T>(string value) { try { return (T)Enum.Parse(typeof(T), value); } catch { throw new Exception("传入的值与枚举值不匹配。"); } }
上面代码是泛型的使用,在之前应用中:
DatabaseType DbType = DatabaseTypeEnumParse<DatabaseType(strDbType);
传入的DatabaseType枚举是这里的泛型T,传入的strDbType是这里的value,通过web.config中配置,
以及private static string strDbType = CommonUtils.GetConfigValueByKey("dbType").ToUpper();,
我们可以得到strDbType=”ORACLE”;
然后回到代码块1-6中:return (T)Enum.Parse(typeof(T), value);
typeof(T)是得到枚举DatabaseType的类型,value是ORACLE,那么这里可以得到:
return (DatabaseType)Enum.Parse(typeof(DatabaseType), ”ORACLE”);
这样最后我们可以得到DatabaseType DbType = DatabaseTypeEnumParse<DatabaseType>(strDbType); 中DbType的值为DatabaseType.ORACLE,下面是这里在AdoHelper类中定义的DbType公有成员的用法:
// <summary> // 根据配置文件中所配置的数据库类型和传入的 // 数据库链接字符串来创建相应数据库连接对象 // </summary> // <param name="connectionString"></param> // <returns></returns> public static IDbConnection CreateDbConnection(string connectionString) { IDbConnection conn = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: conn = new SqlConnection(connectionString); break; case DatabaseType.ORACLE: conn = new OracleConnection(connectionString); break; case DatabaseType.ACCESS: conn = new OleDbConnection(connectionString); break; default: throw new Exception("数据库类型目前不支持!"); } return conn; }
(剖析Step2 End)==================================================
(剖析Step3 Begin)==================================================
代码块1-1中public static string ConnectionString = GetConnectionString("connectionString"); 中通过GetConnectionString(string Key)方法在web.config配置文件中获取数据库连接字符串,配置文件中配置查看代码块1-2,GetConnectionString方法代码块1-7:
// <summary> // 根据传入的Key获取配置文件中 // 相应Key的数据库连接字符串 // </summary> // <param name="Key"></param> // <returns></returns> public static string GetConnectionString(string Key) { try { return CommonUtils.GetConfigValueByKey(Key); } catch { throw new Exception("web.config文件appSettings中数据库连接字符串未配置或配置错误,必须为Key=\"connectionString\""); } }
(剖析Step3 End)==================================================
这里对代码块1-1已经剖析完毕,AdoHelper类中更多的代码剖析将在后面章节中相继完成。
下面是AdoHelper类的完整代码代码如下:
using System; using System.Collections; using System.Collections.Generic; using System.Configuration; using System.Text; using System.Data; using System.Data.Common; using System.Data.SqlClient; using System.Data.OracleClient; using System.Orm.Common; namespace System.Orm.DBUtility { public class AdoHelper { //获取数据库类型 private static string strDbType = CommonUtils.GetConfigValueByKey("dbType").ToUpper(); //将数据库类型转换成枚举类型 public static DatabaseType DbType = DatabaseTypeEnumParse<DatabaseType>(strDbType); //获取数据库连接字符串 public static string ConnectionString = GetConnectionString("connectionString"); public static string DbParmChar = DbFactory.CreateDbParmCharacter(); private static Hashtable parmCache = Hashtable.Synchronized(new Hashtable()); /// <summary> ///通过提供的参数,执行无结果集的数据库操作命令 /// 并返回执行数据库操作所影响的行数。 /// </summary> /// <param name="connectionString">数据库连接字符串</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行<</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回通过执行命令所影响的行数</returns> public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { IDbCommand cmd = DbFactory.CreateDbCommand(); using (IDbConnection conn = DbFactory.CreateDbConnection(connectionString)) { PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val; } } /// <summary> ///通过提供的参数,执行无结果集的数据库操作命令 /// 并返回执行数据库操作所影响的行数。 /// </summary> /// <param name="connectionString">数据库连接字符串</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行<</param> /// <returns>返回通过执行命令所影响的行数</returns> public static int ExecuteNonQuery(string connectionString, CommandType cmdType, string cmdText) { IDbCommand cmd = DbFactory.CreateDbCommand(); using (IDbConnection conn = DbFactory.CreateDbConnection(connectionString)) { PrepareCommand(cmd, conn, null, cmdType, cmdText, null); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val; } } /// <summary> ///通过提供的参数,执行无结果集返回的数据库操作命令 ///并返回执行数据库操作所影响的行数。 /// </summary> /// <remarks> /// e.g.: /// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="conn">数据库连接对象</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回通过执行命令所影响的行数</returns> public static int ExecuteNonQuery(IDbConnection connection, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { IDbCommand cmd = DbFactory.CreateDbCommand(); PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val; } /// <summary> ///通过提供的参数,执行无结果集返回的数据库操作命令 ///并返回执行数据库操作所影响的行数。 /// </summary> /// <remarks> /// e.g.: /// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="conn">数据库连接对象</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行</param> /// <returns>返回通过执行命令所影响的行数</returns> public static int ExecuteNonQuery(IDbConnection connection, CommandType cmdType, string cmdText) { IDbCommand cmd = DbFactory.CreateDbCommand(); PrepareCommand(cmd, connection, null, cmdType, cmdText, null); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val; } /// <summary> ///通过提供的参数,执行无结果集返回的数据库操作命令 ///并返回执行数据库操作所影响的行数。 /// </summary> /// <remarks> /// e.g.: /// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="trans">sql事务对象</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行<</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回通过执行命令所影响的行数</returns> public static int ExecuteNonQuery(IDbTransaction trans, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { IDbConnection conn = null; if (trans == null) { conn = DbFactory.CreateDbConnection(ConnectionString); } else { conn = trans.Connection; } IDbCommand cmd = DbFactory.CreateDbCommand(); PrepareCommand(cmd, conn, trans, cmdType, cmdText, commandParameters); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val; } /// <summary> ///通过提供的参数,执行无结果集返回的数据库操作命令 ///并返回执行数据库操作所影响的行数。 /// </summary> /// <remarks> /// e.g.: /// int result = ExecuteNonQuery(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="trans">sql事务对象</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行<</param> /// <returns>返回通过执行命令所影响的行数</returns> public static int ExecuteNonQuery(IDbTransaction trans, CommandType cmdType, string cmdText) { IDbCommand cmd = DbFactory.CreateDbCommand(); PrepareCommand(cmd, trans.Connection, trans, cmdType, cmdText, null); int val = cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); return val; } /// <summary> /// 使用提供的参数,执行有结果集返回的数据库操作命令 /// 并返回SqlDataReader对象 /// </summary> /// <remarks> /// e.g.: /// SqlDataReader r = ExecuteReader(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="connectionString">数据库连接字符串</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行<</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回SqlDataReader对象</returns> public static IDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { IDbCommand cmd = DbFactory.CreateDbCommand(); IDbConnection conn = DbFactory.CreateDbConnection(connectionString); //我们在这里使用一个 try/catch,因为如果PrepareCommand方法抛出一个异常,我们想在捕获代码里面关闭 //connection连接对象,因为异常发生datareader将不会存在,所以commandBehaviour.CloseConnection //将不会执行。 try { PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters); IDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection); cmd.Parameters.Clear(); return rdr; } catch { conn.Close(); throw; } } /// <summary> ///使用提供的参数,执行有结果集返回的数据库操作命令 /// 并返回SqlDataReader对象 /// </summary> /// <param name="connectionString">数据库连接字符串</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行<</param> /// <returns>返回SqlDataReader对象</returns> public static IDataReader ExecuteReader(string connectionString, CommandType cmdType, string cmdText) { IDbCommand cmd = DbFactory.CreateDbCommand(); IDbConnection conn = DbFactory.CreateDbConnection(connectionString); //我们在这里使用一个 try/catch,因为如果PrepareCommand方法抛出一个异常,我们想在捕获代码里面关闭 //connection连接对象,因为异常发生datareader将不会存在,所以commandBehaviour.CloseConnection //将不会执行。 try { PrepareCommand(cmd, conn, null, cmdType, cmdText, null); IDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection); cmd.Parameters.Clear(); return rdr; } catch { conn.Close(); throw; } } /// <summary> /// 查询数据填充到数据集DataSet中 /// </summary> /// <param name="connectionString">数据库连接字符串</param> /// <param name="cmdType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="cmdText">命令文本</param> /// <param name="commandParameters">参数数组</param> /// <returns>数据集DataSet对象</returns> public static DataSet dataSet(string connectionString, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { DataSet ds = new DataSet(); IDbCommand cmd = DbFactory.CreateDbCommand(); IDbConnection conn = DbFactory.CreateDbConnection(connectionString); try { PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters); IDbDataAdapter sda = DbFactory.CreateDataAdapter(cmd); sda.Fill(ds); return ds; } catch { conn.Close(); throw; } finally { conn.Close(); cmd.Dispose(); } } /// <summary> /// 查询数据填充到数据集DataSet中 /// </summary> /// <param name="connectionString">数据库连接字符串</param> /// <param name="cmdType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="cmdText">命令文本</param> /// <returns>数据集DataSet对象</returns> public static DataSet dataSet(string connectionString, CommandType cmdType, string cmdText) { DataSet ds = new DataSet(); IDbCommand cmd = DbFactory.CreateDbCommand(); IDbConnection conn = DbFactory.CreateDbConnection(connectionString); try { PrepareCommand(cmd, conn, null, cmdType, cmdText, null); IDbDataAdapter sda = DbFactory.CreateDataAdapter(cmd); sda.Fill(ds); return ds; } catch { conn.Close(); throw; } finally { conn.Close(); cmd.Dispose(); } } /// <summary> /// 依靠数据库连接字符串connectionString, /// 使用所提供参数,执行返回首行首列命令 /// </summary> /// <remarks> /// e.g.: /// Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="connectionString">数据库连接字符串</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回一个对象,使用Convert.To{Type}将该对象转换成想要的数据类型。</returns> public static object ExecuteScalar(string connectionString, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { IDbCommand cmd = DbFactory.CreateDbCommand(); using (IDbConnection connection = DbFactory.CreateDbConnection(connectionString)) { PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters); object val = cmd.ExecuteScalar(); cmd.Parameters.Clear(); return val; } } /// <summary> /// 依靠数据库连接字符串connectionString, /// 使用所提供参数,执行返回首行首列命令 /// </summary> /// <remarks> /// e.g.: /// Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="connectionString">数据库连接字符串</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行</param> /// <returns>返回一个对象,使用Convert.To{Type}将该对象转换成想要的数据类型。</returns> public static object ExecuteScalar(string connectionString, CommandType cmdType, string cmdText) { IDbCommand cmd = DbFactory.CreateDbCommand(); using (IDbConnection connection = DbFactory.CreateDbConnection(connectionString)) { PrepareCommand(cmd, connection, null, cmdType, cmdText, null); object val = cmd.ExecuteScalar(); cmd.Parameters.Clear(); return val; } } /// <summary> ///依靠数据库连接字符串connectionString, /// 使用所提供参数,执行返回首行首列命令 /// </summary> /// <remarks> /// e.g.: /// Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="conn">数据库连接对象</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回一个对象,使用Convert.To{Type}将该对象转换成想要的数据类型。</returns> public static object ExecuteScalar(IDbConnection connection, CommandType cmdType, string cmdText, params IDbDataParameter[] commandParameters) { IDbCommand cmd = DbFactory.CreateDbCommand(); PrepareCommand(cmd, connection, null, cmdType, cmdText, commandParameters); object val = cmd.ExecuteScalar(); cmd.Parameters.Clear(); return val; } /// <summary> ///依靠数据库连接字符串connectionString, /// 使用所提供参数,执行返回首行首列命令 /// </summary> /// <remarks> /// e.g.: /// Object obj = ExecuteScalar(connString, CommandType.StoredProcedure, "PublishOrders", new SqlParameter("@prodid", 24)); /// </remarks> /// <param name="conn">数据库连接对象</param> /// <param name="commandType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="commandText">存储过程名称或者T-SQL命令行</param> /// <param name="commandParameters">执行命令所需的参数数组</param> /// <returns>返回一个对象,使用Convert.To{Type}将该对象转换成想要的数据类型。</returns> public static object ExecuteScalar(IDbConnection connection, CommandType cmdType, string cmdText) { IDbCommand cmd = DbFactory.CreateDbCommand(); PrepareCommand(cmd, connection, null, cmdType, cmdText, null); object val = cmd.ExecuteScalar(); cmd.Parameters.Clear(); return val; } /// <summary> /// add parameter array to the cache /// </summary> /// <param name="cacheKey">Key to the parameter cache</param> /// <param name="cmdParms">an array of SqlParamters to be cached</param> public static void CacheParameters(string cacheKey, params IDbDataParameter[] commandParameters) { parmCache[cacheKey] = commandParameters; } /// <summary> /// 查询缓存参数 /// </summary> /// <param name="cacheKey">使用缓存名称查找值</param> /// <returns>缓存参数数组</returns> public static IDbDataParameter[] GetCachedParameters(string cacheKey) { IDbDataParameter[] cachedParms = (IDbDataParameter[])parmCache[cacheKey]; if (cachedParms == null) return null; IDbDataParameter[] clonedParms = new IDbDataParameter[cachedParms.Length]; for (int i = 0, j = cachedParms.Length; i < j; i++) clonedParms[i] = (IDbDataParameter)((ICloneable)cachedParms[i]).Clone(); return clonedParms; } /// <summary> /// 为即将执行准备一个命令 /// </summary> /// <param name="cmd">SqlCommand对象</param> /// <param name="conn">SqlConnection对象</param> /// <param name="trans">IDbTransaction对象</param> /// <param name="cmdType">执行命令的类型(存储过程或T-SQL,等等)</param> /// <param name="cmdText">存储过程名称或者T-SQL命令行, e.g. Select * from Products</param> /// <param name="cmdParms">SqlParameters to use in the command</param> private static void PrepareCommand(IDbCommand cmd, IDbConnection conn, IDbTransaction trans, CommandType cmdType, string cmdText, IDbDataParameter[] cmdParms) { 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 (IDbDataParameter parm in cmdParms) cmd.Parameters.Add(parm); } } /// <summary> /// 根据传入的Key获取配置文件中 /// 相应Key的数据库连接字符串 /// </summary> /// <param name="Key"></param> /// <returns></returns> public static string GetConnectionString(string Key) { try { return CommonUtils.GetConfigValueByKey(Key); } catch { throw new Exception("web.config文件appSettings中数据库连接字符串未配置或配置错误,必须为Key=\"connectionString\""); } } /// <summary> /// 用于数据库类型的字符串枚举转换 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="value"></param> /// <returns></returns> public static T DatabaseTypeEnumParse<T>(string value) { try { return CommonUtils.EnumParse<T>(value); } catch { throw new Exception("数据库类型\"" + value + "\"错误,请检查!"); } } } }
在上面代码中用到了DbFactory类来创建数据库连接,适配器,事务等等对象。这里的工厂类的作用是根据配置文件的DbType指定的数据库类型来创建,目前支持3种数据库类型,如果需要新增数据库类型,只需修改此类中代码,其它地方无需改变。
代码如下:
using System; using System.Configuration; using System.Data; using System.Collections; using System.Data.SqlClient; using System.Data.OracleClient; using System.Data.OleDb; using System.Data.Odbc; using System.Orm.Common; namespace System.Orm.DBUtility { public class DbFactory { /// <summary> /// 根据配置文件中所配置的数据库类型 /// 来获取命令参数中的参数符号oracle为":",sqlserver为"@" /// </summary> /// <returns></returns> public static string CreateDbParmCharacter() { string character = string.Empty; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: character = "@"; break; case DatabaseType.ORACLE: character = ":"; break; case DatabaseType.ACCESS: character = "@"; break; default: throw new Exception("数据库类型目前不支持!"); } return character; } /// <summary> /// 根据配置文件中所配置的数据库类型和传入的 /// 数据库链接字符串来创建相应数据库连接对象 /// </summary> /// <param name="connectionString"></param> /// <returns></returns> public static IDbConnection CreateDbConnection(string connectionString) { IDbConnection conn = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: conn = new SqlConnection(connectionString); break; case DatabaseType.ORACLE: conn = new OracleConnection(connectionString); break; case DatabaseType.ACCESS: conn = new OleDbConnection(connectionString); break; default: throw new Exception("数据库类型目前不支持!"); } return conn; } /// <summary> /// 根据配置文件中所配置的数据库类型 /// 来创建相应数据库命令对象 /// </summary> /// <returns></returns> public static IDbCommand CreateDbCommand() { IDbCommand cmd = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: cmd = new SqlCommand(); break; case DatabaseType.ORACLE: cmd = new OracleCommand(); break; case DatabaseType.ACCESS: cmd = new OleDbCommand(); break; default: throw new Exception("数据库类型目前不支持!"); } return cmd; } /// <summary> /// 根据配置文件中所配置的数据库类型 /// 来创建相应数据库适配器对象 /// </summary> /// <returns></returns> public static IDbDataAdapter CreateDataAdapter() { IDbDataAdapter adapter = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: adapter = new SqlDataAdapter(); break; case DatabaseType.ORACLE: adapter = new OracleDataAdapter(); break; case DatabaseType.ACCESS: adapter = new OleDbDataAdapter(); break; default: throw new Exception("数据库类型目前不支持!"); } return adapter; } /// <summary> /// 根据配置文件中所配置的数据库类型 /// 和传入的命令对象来创建相应数据库适配器对象 /// </summary> /// <returns></returns> public static IDbDataAdapter CreateDataAdapter(IDbCommand cmd) { IDbDataAdapter adapter = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: adapter = new SqlDataAdapter((SqlCommand)cmd); break; case DatabaseType.ORACLE: adapter = new OracleDataAdapter((OracleCommand)cmd); break; case DatabaseType.ACCESS: adapter = new OleDbDataAdapter((OleDbCommand)cmd); break; default: throw new Exception("数据库类型目前不支持!"); } return adapter; } /// <summary> /// 根据配置文件中所配置的数据库类型 /// 来创建相应数据库的参数对象 /// </summary> /// <returns></returns> public static IDbDataParameter CreateDbParameter() { IDbDataParameter param = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: param = new SqlParameter(); break; case DatabaseType.ORACLE: param = new OracleParameter(); break; case DatabaseType.ACCESS: param = new OleDbParameter(); break; default: throw new Exception("数据库类型目前不支持!"); } return param; } /// <summary> /// 根据配置文件中所配置的数据库类型 /// 和传入的参数来创建相应数据库的参数数组对象 /// </summary> /// <returns></returns> public static IDbDataParameter[] CreateDbParameters(int size) { int i = 0; IDbDataParameter[] param = null; switch (AdoHelper.DbType) { case DatabaseType.SQLSERVER: param = new SqlParameter[size]; while (i < size) { param[i] = new SqlParameter(); i++; } break; case DatabaseType.ORACLE: param = new OracleParameter[size]; while (i < size) { param[i] = new OracleParameter(); i++; } break; case DatabaseType.ACCESS: param = new OleDbParameter[size]; while (i < size){param[i] = new OleDbParameter();i++;} break; default: throw new Exception("数据库类型目前不支持!"); } return param; } /// <summary> /// 根据配置文件中所配置的数据库类型 /// 来创建相应数据库的事物对象 /// </summary> /// <returns></returns> public static IDbTransaction CreateDbTransaction() { IDbConnection conn = CreateDbConnection(AdoHelper.ConnectionString); if (conn.State == ConnectionState.Closed) { conn.Open(); } return conn.BeginTransaction(); } } }
在AdoHelper类中用到了CommonUtils工具类,DbFactory类中用到了DatabaseType枚举
代码如下:
using System; using System.Collections.Generic; using System.Text; using System.Configuration; using System.Reflection; namespace System.Orm.Common { public class CommonUtils { /// <summary> /// 用于字符串和枚举类型的转换 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="value"></param> /// <returns></returns> public static T EnumParse<T>(string value) { try { return (T)Enum.Parse(typeof(T), value); } catch { throw new Exception("传入的值与枚举值不匹配。"); } } /// <summary> /// 根据传入的Key获取配置文件中的Value值 /// </summary> /// <param name="Key"></param> /// <returns></returns> public static string GetConfigValueByKey(string Key) { try { return ConfigurationManager.AppSettings[Key].ToString(); } catch { throw new Exception("web.config中 Key=\"" + Key + "\"未配置或配置错误!"); } } public static Boolean IsNullOrEmpty(Object value) { if (value == null) return true; if (String.IsNullOrEmpty(value.ToString())) return true; return false; } } } using System; using System.Collections.Generic; using System.Text; namespace System.Orm.DBUtility { /// <summary> /// 数据库类型枚举,需要扩展类型可在此添加 /// </summary> public enum DatabaseType { SQLSERVER, ORACLE, ACCESS, MYSQL } }
在CommonUtils类中使用到了TypeUtils类进行类型转换:
using System; using System.Collections.Generic; using System.Text; namespace System.Orm.Common { public class TypeUtils { public static object ConvertForType(object value,Type type) { switch (type.FullName) { case "System.String": value = value.ToString(); break; case "System.Boolean": value = bool.Parse(value.ToString()); break; case "System.Int16": case "System.Int32": case "System.Int64": value = int.Parse(value.ToString()); break; case "System.Double": value = double.Parse(value.ToString()); break; case "System.Decimal": value = new decimal(double.Parse(value.ToString())); break; } return value; } } }
数据库操作类代码基本如上全部。