带有EF 6的MySql连接器

时间:2014-02-10 15:01:21

标签: mysql ado.net entity-framework-6 ef-database-first

我遇到了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,但没有任何改变。有人可以告诉我发生了什么事吗?

由于

3 个答案:

答案 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