我遇到了MySql Connector(6.8.3)和EF6的奇怪问题。我正在开发一个WebApi项目,我使用MySql和EF6以及数据库第一种方法。一切工作正常[甚至部署在其中一个测试服务器上],直到我将数据库从“测试”数据库更改为连接字符串中的“生产”数据库[只是数据库名称]并更新了模型[只是为了看不到任何内容! ]。之后,它无法连接到数据库。所以,我改回了连接字符串并重建了解决方案,然后我收到了一堆'Mapping'警告。我删除了模型并尝试从数据库中再次创建模型。现在,我收到以下消息
您的项目引用了最新版本的Entity Framework; 但是,与此兼容的Entity Framework数据库提供程序 找不到您的数据连接版本。退出此向导, 安装兼容的提供程序,然后重建您的项目 执行此操作
这是配置文件
<!-- 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,但没有任何改变。有人可以告诉我发生了什么事吗?
由于
答案 0 :(得分:3)
我遇到了类似的问题,我使用Nuget将MySql连接器引用到我的项目中。但是服务器在机器本身安装了另一个版本的MySql连接器。因此应用程序优先考虑安装在服务器GAC中的MySql连接器。
你所要做的就是
在服务器中卸载MySql连接器
或
在服务器中安装合适的MySql连接器(在您的情况下为v6.8.3)并卸载其余的
或
将您的提供程序类型版本更改为服务器中安装的版本。
答案 1 :(得分:3)
血淋淋的地狱,也有同样的问题。
我对.NET环境很陌生,所以,我不知道软件包管理器和所有工作如何工作但似乎当我导入MySQL连接器的程序集时,它会更新&# 34; web.conf&#34;提供者使用错误参数的文件。
就我而言,使用EF6和MySQL Connector for EF v6.8.3.0,以下内容对我有用:
<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>
希望它有助于某人
答案 2 :(得分:0)
我知道问题所在,你必须做下一步: 1.右键单击项目 2.管理NuGet包 3.删除MySql.Data 4.现在你可以做你想做的事 5.完成后,返回Manage NuGet Packages并添加MySql.Data.Entity :)
祝你好运 nofar eliasi