如何在ADO中使用接口的抽象数据提供程序
在cofig中 appSettings下,配置数据连接类型
<appSettings> <!--这个键值映射到枚举值中的某个值--> <add key="provider" value="SqlServer"/> <add key="ConnectionString" value="server=服务器名;User ID=用户名;Password=密码;database=数据库名;Max Pool Size=3000;Connect TimeOut=60;Pooling=true"/> </appSettings>
使用接口的抽象数据提供程序
Console.WriteLine("******Simple Connecion Factory*****"); IDbConnection mycon = GetConnection(DataProvider.SqlServer); Console.WriteLine(mycon.GetType()); //通过配置文件 string dataProvString = ConfigurationSettings.AppSettings["provider"]; DataProvider dp = DataProvider.None; if (Enum.IsDefined(typeof(DataProvider), dataProvString)) { dp = (DataProvider)Enum.Parse(typeof(DataProvider), dataProvString); } else { Console.WriteLine("Soryy"); } IDbConnection myCn = GetConnection(dp); if (myCn != null) { Console.WriteLine(myCn.GetType().Name); } enum DataProvider { SqlServer, OleDb, Odbc, None } static IDbConnection GetConnection(DataProvider dp) { IDbConnection con = null; switch (dp) { case DataProvider.SqlServer: con = new SqlConnection(); break; case DataProvider.OleDb: con = new OleDbConnection(); break; case DataProvider.Odbc: con = new OdbcConnection(); break; case DataProvider.None: break; default: break; } return con; ; }
ADO.NET数据提供程序工厂模型
.NET数据提供程序工厂模式能让我们用多种数据访问类型构建单个代码库。而且通过应用程序配置文件(和全新的<connectionstrings>片段),我们无需重新编译、重新部署程序集就能够更改和获取提供程序和连接字符串。
* 数据提供程序中的类都从相同基类继承并且都被定义在System.Data.Command命名空间内。
*DbCommand:所有命令类的抽象基类
*DbConnction:所有连接类的抽象基类
*DbDataAdapter:所有数据适配器类的抽象基类。
*DbDataReader:所有数据读取器类的抽象基类。
*DbParameter:所有参数类的抽象基类
*DbTransaction :所有事务类的抽象基类
另外,每个微软提供的数据提供程序都有一个继承自System.Data.DbProviderFaCtory 的类。这个基类定义了一些方法来获取某数据提供程序的数据对象
完整的数据提供程序工厂的例子
string dp = ConfigurationSettings.AppSettings["provider"]; string constr = ConfigurationSettings.AppSettings["ConnectionString"]; DbProviderFactory df = DbProviderFactories.GetFactory(dp); using (DbConnection cn = df.CreateConnection()) { Console.WriteLine(cn.GetType().Name); cn.ConnectionString = constr; cn.Open(); DbCommand cmd = df.CreateCommand(); Console.WriteLine(cmd.GetType().Name); cmd.Connection = cn; cmd.CommandText = "select * from TCustomer"; using (DbDataReader dr = cmd.ExecuteReader()) { Console.WriteLine(dr.GetType().Name); while (dr.Read()) { Console.WriteLine(dr["CreateTime"].ToString()); } } }
数据提供程序工厂模型的潜在缺陷
尽管这个模型很强.但是你要知道,代码库其实只能通过抽象基类的成员来使用所有提供程序通用的一些类型和方法。因此在写代码库的时候.你会被局限于system.Data.Common命名空间下的
DbConnection 、 DbCommand 等其他类型公开的成员。
这样,你会发现这种“泛化的”方式使得我们不能直接访问特定DBMS的漂亮功能。如果我们必须调用基础提供程序(比如SqlConnection)的特殊成员,那么可以通过显式强制类型转换就能实现
然而,这样会使代码变得不易维护(也缺乏灵活性).因为我们必须增加许多运行时检测。但如果你希望以最灵活的方式构建数据访问阵,数据提供程序工厂模划提供了一个很好的机制
[connectionstrings]元素
我们的连接字符串数据现在在*.config文件的<appSettings>元素中,应用程序配置文件定义了一个新的元素,叫做<connectionstrings>;你能在这个元素内设置任意多的名称/值组合并且能通过
configurationManager.Connectionstrings 索引器以编程方式访问。这种方式的(相比使用<appsettings>元素和configurationManager.Appsettings 索引器来访问)好处在于它能为你的应用程序以一个统一的方式定义多个连接字符串
具体配置如下
<connectionStrings> <add name="ECPublic" connectionString="server=服务器名;User ID=用户名;Password=密码;database=数据库名;Min Pool Size=100;Max Pool Size=200;"/> <add name="CRM" connectionString="server=服务器名;User ID=用户名;Password=密码;database=数据库名;Min Pool Size=100;Max Pool Size=200;"/> </connectionStrings>