带有 EF 6 的 MySql 连接器
Posted
技术标签:
【中文标题】带有 EF 6 的 MySql 连接器【英文标题】:MySql Connector with EF 6 【发布时间】:2014-03-07 23:33:23 【问题描述】: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,但没有任何改变。谁能告诉我这是怎么回事?
谢谢
【问题讨论】:
我还在努力解决这个问题!感谢任何帮助或建议? 确保您的项目包含对 MySQL EF 提供程序的引用 - 该消息表明 EF 设计器找不到可用于与数据库通信的提供程序。一旦您的项目中有提供程序,请确保在启动向导之前构建项目。这一步非常重要。 问题看起来像这样:entityframework.codeplex.com/workitem/1869 @Pawel 在我更改连接字符串之前它运行良好。除了连接,我什么都没改变!! @Kuzgun 可能是。但我不确定! 【参考方案1】:我遇到了类似的问题,我使用 Nuget 引用了我的项目的 MySql 连接器。但是服务器在机器本身安装了另一个版本的 MySql 连接器。所以应用程序优先考虑安装在服务器 GAC 中的 MySql 连接器。
你所要做的就是要么
在服务器中卸载 MySql 连接器
或
在服务器中安装合适的 MySql 连接器(在你的情况下是 v6.8.3)并卸载其余的
或
将您的提供程序类型版本更改为安装在服务器中的版本。
【讨论】:
我不确定你是否听懂了这个问题!我能够使用测试数据库连接很好地测试应用程序。当我将连接字符串更改为生产数据库时,问题就开始了。与任何服务器无关!!我的 qpp 甚至没有部署在任何地方。我正在从我的开发机器上调试它。 没有针对@Sen Jacob 的意见.....我不确定是谁授予了“赏金”。但是,这很有趣,因为这个答案甚至与我的问题无关!! @usp 我已经标记了答案以引起版主的注意。我想他们会取消赏金【参考方案2】:该死的,有同样的问题。
我对 .NET 环境还很陌生,所以我不知道包管理器和所有程序是如何工作的,但似乎当我为 MySQL 连接器导入程序集时,它会更新“web.conf”文件提供者的参数错误。
在我的情况下,使用 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>
希望对某人有所帮助
【讨论】:
你用的是什么版本的 MySql for Visual Studio?我在 1.2.3 和 6.8.3 上,我仍然得到错误。我也有这个。我试过 6.9.2 RC 也失败了。【参考方案3】:我知道问题出在哪里,您必须执行以下步骤: 1.右键项目 2. 管理 NuGet 包 3.删除MySql.Data 4.现在你可以做你想做的事 5.完成后,返回Manage NuGet Packages并添加MySql.Data.Entity :)
祝你好运 诺法埃利亚西
【讨论】:
以上是关于带有 EF 6 的 MySql 连接器的主要内容,如果未能解决你的问题,请参考以下文章
Asp.net Core 6.0 使用EF Model First 连接mysql
Asp.net Core 6.0 使用EF Model First 连接mysql
EF6+MySql 软件配置环境 EF连接不到mysql问题 实体数据模型向导 选不到mysql
带有 MySQL 连接器 6.4.3 的实体框架 4 自动生成表导致“列长度”异常