对于使用ADO.NET通用接口创建对象
创始人
2024-06-18 14:41:04
0

对于ADO.NET通用接口的相关使用还是比较常见,就使用ADO.NET DbProviderFactories并扩充兼容mysql我深入的研究了一下,我们现在一起来看看吧。ADO.NET2.0 为各种ADO.NET类引入了一个提供程序工厂的模型以及通用基类。

ADO.NET通用接口的限制:接口不易扩展,ADO.NET1.1无法创建某些类的实例,ADO.NET1.1无法判断可用的.NET数据提供程序。提供工厂模型如何解决上述限制,通过抽象积累来扩展ADO,NET模型。#t#

使用ADO.NET DbProviderFactories类来创建对象。提供程序工厂模型的限制,许多查询结构都是数据库特有的。为参数化查询设置CommandText时,可能需要提供程序特有的代码,指定参数数据类型可能需要提供程序特有的代码。为了使开发的代码通用。

不局限于特定的数据库,本次开发中决定使用DbProviderFactory+标准SQL,以开发一个适用于mysql和 sqlserver的封装,但DbProviderFactories 并没有提供对mysql的DbProviderFactory的支持,所以需要扩充ADO.NET通用接口兼容mysql,而且在ADO.net 2.0中mysql和sqlserver的ParameterMarkerFormat都有bug,ADO.NET通用接口所以扩展类要解决这个bug。

  1. public static class DbProviderFactoriesEx  { 
  2.  public static DbProviderFactory GetFactory(string providerName)  { 
  3.  if (providerName == null)  throw new ArgumentNullException("providerName");  
  4. DbProviderFactory dbFactory;  switch (providerName) 
  5.  {  case "MySql.Data.MySqlClient":  return new MySqlClientFactory(); 
  6.  default:  return DbProviderFactories.GetFactory(providerName);  }  } 
  7.  public static string GetParameterMarkerFormat(DbConnection connect) 
  8.  {  if (connect == null)  throw new ArgumentNullException("connect"); 
  9.  Type type = connect.GetType();  if (type == typeof(MySql.Data.MySqlClient.MySqlConnection))
  10.   return "?{0}";//mysql bug  if (type == typeof(System.Data.SqlClient.SqlConnection)) 
  11.  return "@{0}";//ms bug  connect.Open();  string result = connect.GetSchema("DataSourceInformation").Rows[0]["ParameterMarkerFormat"].ToString();  
  12. connect.Close();  returresult;  }  }  

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...