asp.netcore3.0 netstandard2.1 使用 DbProviderFactories 连接数据库

System.ArgumentException:“The specified invariant name ‘MySql.Data.MySqlClient’ wasn’t found in the list of registered .NET Data Providers.”

NET Core的数据库连接与.NET Framework略有不同。在.NET Framework中,程序可用的数据库驱动程序在整个系统范围内(通过machine.config)自动可用。也就是 mysql的.net连接驱动(mysql-connector-net-x.x.x.x.msi)就可以了。
而.NET Core中不是这种情况,您必须注册要使用的数据库驱动程序-通常在Program.cs或中Startup.cs。使用 以下DbProviderFactories.RegisterFactory方法完成注册:

SqlServer
using System.Data.SqlClient;
DbProviderFactories.RegisterFactory(“System.Data.SqlClient”,SqlClientFactory.Instance);

MySql
using MySql.Data.MySqlClient;
DbProviderFactroes.RegisterFactory(“MySql.Data.MySqlClient”,MySqlClientFactory.Instance);

PostgreSql
using Npgsql;
DbProviderFactories.RegisterFactory(“Npgsql”,NpgsqlFactory.Instance);

SqlLite
using Microsoft.Data.Sqlite;
DbProviderFactories.RegisterFactory(“Microsoft.Data.Sqlite”,SqliteFactory.Instance);

使用
DbProviderFactory factory = DbProviderFactories.GetFactory(“MySql.Data.MySqlClient”);
//创建一个数据客户端连接
DbConnection conn = factory.CreateConnection();

升级
在上述方法过程中是使用的直接注册工厂单例完成的;
按照官方的API 可以使用注册指定的工厂类型和应用程序集来完成
public static void RegisterFactory(string providerInvarintName,string factoryTypeAssemblyQualifiedName);

例如mysql
DbProviderFactories.RegisterFactory(providerName, “MySql.Data.MySqlClient.MySqlClientFactory,MySql.Data”);
前面是工厂的类型名称,后面是类所在的应用程序集,即可达到同样的效果;
这样的好处就是自己在封装数据库方法的时候不需要再将mysql,sqlserver的包一起打入到框架中,而是交由使用的web或者desktop项目来加载数据库客户端包,用法就可以像 .netframework项目一样的使用了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值