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的主要内容,如果未能解决你的问题,请参考以下文章