加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

.net core下使用DbProviderFactories.GetFactory("&#34

发布时间:2020-12-16 08:56:44 所属栏目:asp.Net 来源:网络整理
导读:前言:我们有时候会有一种需求,需要连接很多的数据库,如:mysql,sqlserver,oracle等等,需要把这些数据库里的数据抽取出来加工后,返回给客户端使用。 在.net framework中是可以使用: DbProviderFactories.GetFactory("MySql.Data.MySqlClient");----创建

  前言:我们有时候会有一种需求,需要连接很多的数据库,如:mysql,sqlserver,oracle等等,需要把这些数据库里的数据抽取出来加工后,返回给客户端使用。

  在.net framework中是可以使用:

    DbProviderFactories.GetFactory("MySql.Data.MySqlClient");----创建Mysql数据库工厂

    DbProviderFactories.GetFactory("System.Data.SqlClient"); ------创建Sqlserver数据库连接工厂

  进行数据库连接的,当然还需要一些连接字符串的设置。

?

但是在.net core中直接使用这种方式会出现异常,如下图:是不是很郁闷???

?

而在core项目里的写法,本人根据网上大神的一些案例,对写法做了一些变动,代码:

if (_providerName != null)
{
    if (_providerName == "System.Data.SqlClient")
    {
        _dbType = DBType.SqlServer;
        _factory = SqlClientFactory.Instance;
    }
    else MySql.Data.MySqlClient DBType.MySql;
        _factory = MySqlClientFactory.Instance;
    }
}             

也就是,我们自己手动根据配置的数据(我这里根据配置的变量providerName-数据库客户端程序集名称)区分,直接将Sqlserver的单例工厂(SqlClientFactory.Instance)和MySql的单例工厂(MySqlClientFactory.Instance)放到基类工厂:DbProviderFactory _factory;

通过这样改写就绕过了原来的写法,解决了本文所说的这个问题。

?

参考大神文章:?.Net Core2.0下使用Dapper遇到的问题? ?,以后有时间对Dapper学习下,对多个数据库的统一链接的类库,好用!!!

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读