ef5.0 怎么连接mysql

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ef5.0 怎么连接mysql相关的知识,希望对你有一定的参考价值。

参考技术A 1)由以往的经验:在ADO.NET中,要操作多个数据库,那就多写两个SqlHelper吧,或封装下,能动态的修改链接字符串。因此想到在这里能不能建多个ADO.NET实体数据模型呢?于是乎就有了这样两个文件:SealDBModel.edmx及UcmsDBModel.edmx。
2)SealDBModel是主要的,因此在Server中对其处理,作了继承。也同时使用了UcmsDBModel。
3)这段代码是有问题的,当要同时操作不同数据库,且有数据有效性的时候,就会发现前面的一个成功了,后面的一个失败了。怎么办呢?EF的事务机制显然已经满足不了程序的要求了,怎么办呢?加TransactionScope吧。
4)于是乎就有了这样一段代码:

namespace Seal_Services

public class seal_testServer : BaseServer<seal_test>, Iseal_usersServer

public void TTTT()

using (TransactionScope scope = new TransactionScope())

try

seal_test test = new seal_test()

name = "1111",
age = 1
;
base.AddEntity(test);
base.db.SaveChanges();
BaseUCMSServer<au_Role> ucmsserver = new BaseUCMSServer<au_Role>();
au_Role role = new au_Role();
role = ucmsserver.FindEntitie(c => c.id == 7);
role.role_name = "BBBBBBBBBBB";
ucmsserver.UpdateEntity(role);
ucmsserver.db.SaveChangesForUCMS();

scope.Complete();

catch (System.Exception ex)

throw ex;






5)可还是有问题呀,在处理第二个Server时会抛出异常“ 基础提供程序在 Open 上失败 ”。然而可以肯定的是,数据库链接字符串是正确的。可却报错了,这是为什么呢?【这是我电脑环境上的一个坑】
6)经过分析(翻了无数百度相同的转贴后...),想到了,会不会有SQL配置相关?导致了TransactionScope的使用失败?
7)打开 Sql Server Configuration Manager时,我看到SQL Server服务,显示的是:远程过程调用失败。这个???既然失败,那就让它正确。于是:打开 控制面板-卸载 找到 Express LocalDB。坚定的将其【卸载】。返回程序中,再执行。

带有 EF 6 的 MySql 连接器

【中文标题】带有 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 :)

祝你好运 诺法埃利亚西

【讨论】:

以上是关于ef5.0 怎么连接mysql的主要内容,如果未能解决你的问题,请参考以下文章

谁用过SSL连接mysql,2026错误怎么解决

mysql数据库的最大连接数怎么查询?

java 连接mysql数据库怎么连接

java是怎么连接mysql数据库的

mysql数据库软件怎么使用,如何连接数据?

在eclipse里jdbc连接mysql 怎么安装