博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Providesfactories类的应用(转)
阅读量:6452 次
发布时间:2019-06-23

本文共 1587 字,大约阅读时间需要 5 分钟。

感觉很实用:只不过微软也有直接工的东西可以完成
ADO.NET 1.0和1.1中基于接口的方法的复杂性之一在于:您无法在接口上调用构造函数,您必须创建特定类的具体实例。以前的API(如OLE DB和ADO)通过重载连接字符串来解决这一问题。连接字符串包含提供程序的COM PROGID,而正确的DataSource类是基于该PROGID创建的。因为OLE DB DataSource PROGID存储在注册表中,所以这是可能的。
' VB6 ADO code, Connection is an interface (actually it's _Connection)
Dim conn as Connection
' note that the default provider is MSDASQL, the OLE DB provider for ODBC
' this uses the OLE DB provider for SQL Server
conn.ConnectionString = "provider=sqloledb;.." ' other parameters deleted
conn.Open
    ADO.NET 2.0具有与此对应的解决方案。每个数据提供程序都在.NET machine.config中注册了一个ProvidesFactory类和一个提供程序字符串。有一个ProvidesFactory基类(DbProvidesFactory)和一个System.Data.Common.ProvidesFactories类,可以返回有关machine.config中注册的不同数据提供程序信息的DataTable,而且还可以在给定该DataTable中的提供程序字符串(称为ProviderInvariantName)或DataRow的情况下检索正确的ProvidesFactory。以前通常按如下方式编写条件代码:
enum provider {sqlserver, oracle, oledb, odbc};
// determine provider from configuration
provider prov = GetProviderFromConfigFile();
IDbConnection conn = null;
switch (prov) {
    case provider.sqlserver:
        conn = new SqlConnection();
        break;
    case provider.oracle:
        conn = new OracleConnection();
        break;
    case provider.oledb:
        conn = new OleDbConnection();
        break;
    case provider.odbc:
        conn = new OdbcConnection();
        break;
    // add new providers as the application supports them
}
    现在可以按如下方式编写:
// get ProviderInvariantString from configuration
string provstring = GetProviderInvariantString();
DbProvidesFactory fact = DbProvidesFactories.GetFactory(provstring);
IDbConnection = fact.CreateConnection();
    由于出现了用于检索安装在计算机上的数据提供程序以及为每个数据提供程序检索Provide***ctory的标准,因此带来了其他一些有趣的可能性。

转载地址:http://eygwo.baihongyu.com/

你可能感兴趣的文章
JMeter IP欺骗压测
查看>>
Serializers 序列化组件
查看>>
最简单的RPC框架实现
查看>>
Servlet 技术全总结 (已完成,不定期增加内容)
查看>>
[JSOI2008]星球大战starwar BZOJ1015
查看>>
CountDownLatch与thread-join()的区别
查看>>
linux下MySQL安装登录及操作
查看>>
centos 7 部署LDAP服务
查看>>
揭秘马云帝国内幕:马云的野心有多大
查看>>
topcoder srm 680 div1
查看>>
算法专题(1)-信息学基本解题流程!
查看>>
模拟文件系统
查看>>
使用SSH连接Windows10 Ubuntu (WSL),Pycharm
查看>>
poj2155
查看>>
CSS动画之转换模块
查看>>
swift - UITextField 的用法
查看>>
检索和关闭游标+检索游标+关闭游标
查看>>
[开源]KJFramework.Message 智能二进制消息框架 -- 性能提升
查看>>
iOS项目分层
查看>>
CocosCreator 小知识
查看>>