我的MySql连接器(6.8.3)和EF6出现了一个奇怪的问题。我在WebApi项目中使用MySql和EF6,并采用数据库优先的方法。一切都很好[甚至部署在其中一个测试服务器上],直到我在连接字符串中将数据库从"测试"数据库更改为"生产"数据库[只是数据库名称],并更新了模型[只是为了查看没有任何损坏!]。之后,它无法连接到数据库。所以,我把连接字符串改回并重新构建了解决方案,然后我收到了一堆"映射"警告。我删除了该模型,并尝试从数据库中再次创建该模型。现在,我收到以下消息
您的项目引用了最新版本的实体框架;但是,与此兼容的实体框架数据库提供程序找不到数据连接的版本。退出此向导,安装兼容的提供程序,然后在执行此操作
这是配置文件
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</configSections>
<system.data>
<DbProviderFactories>
<clear/>
<remove invariant="MySql.Data.MySqlClient"/>
<add name="MySql.Data.MySqlClient" description="ADO.Net driver for MySQL" invariant="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data,Version=6.8.3.0, Culture=neutral,PublicKeyToken=c5687fc88969c44d"/>
</DbProviderFactories>
</system.data>
<entityFramework codeConfigurationType="MySql.Data.Entity.MySqlEFConfiguration, MySql.Data.Entity.EF6">
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
<providers>
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6" />
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
我试着从Nuget重新安装连接器和EF,但没有任何变化。有人能告诉我发生了什么事吗?
感谢
我也遇到过类似的问题,我的Nuget项目引用了MySql连接器。但服务器本身安装了另一个版本的MySql连接器。因此,应用程序优先考虑安装在服务器GAC中的MySql连接器。
你所要做的就是要么
卸载服务器中的MySql连接器
或
在服务器中安装合适的MySql连接器(在您的情况下为v6.8.3),并卸载其余
或
将您的提供程序类型版本更改为安装在服务器中的版本。
血腥地狱,也有同样的问题。
我对.NET环境还很陌生,所以我不知道包管理器和所有程序是如何工作的,但当我导入MySQL连接器的程序集时,它似乎会使用错误的提供程序参数更新"web.conf"文件。
在我的案例中,使用EF6和用于EF v6.8.3.0的MySQL连接器,以下对我有效:
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
<providers>
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6"></provider>
</providers>
</entityFramework>
希望它能帮助
我知道问题出在哪里,您必须执行以下步骤:1.右键单击项目2.管理NuGet包3.删除MySql.Data4.现在你可以做你想做的事了5.完成后,返回管理NuGet包并添加MySql.Data.Entity:)
祝你好运诺法尔埃利亚西