ADO.NET中怎么创建一个通用接口对象

本篇文章为大家展示了ADO.NET中怎么创建一个通用接口对象,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

专注于为中小企业提供成都网站建设、成都网站制作服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业鲤城免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

使用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。

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

上述内容就是ADO.NET中怎么创建一个通用接口对象,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。

当前名称:ADO.NET中怎么创建一个通用接口对象
链接URL:https://www.cdcxhl.com/article6/jdopig.html

成都网站建设公司_创新互联,为您提供外贸建站网站营销用户体验品牌网站设计营销型网站建设外贸网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

绵阳服务器托管