VS+mysql+EF搭建
2016年7月6日更新:
vs2010只需要安装mysql的.net connector就可以
vs2012, vs2015都需要安装.net connector + ODBC connector才行
并且, 安装完ODBC connector后, 需要到 控制面板->管理工具->ODBC数据源 里面去添加Mysql数据源
====================================================================
安装VS2010后, 要先装这两个扩展包, 因为2010不是默认安装的.
首先从扩展管理器中安装NuGet Package Manager
再从NuGet Package Manager中安装最新版EF
再从NuGet Package Manager中搜索"mysql", 装搜出来的前三个插件, 都要装最新版的.
此时去新建实体数据模型, 可能会出现一个简单的报错:
在 .NET Framework Data Provider for Microsoft SQL Server Compact 3.5 中发生错误。请与提供程序供应商联系以解决此问题。
解决方案如下:
1.打开注册表
2.分别删掉以下两个注册表文件
32位操作系统
(1) HKEY_LOCAL_MACHINESOFTWAREMicrosoftVisualStudio10.0DataProviders{7C602B5B-ACCB-4acd-9DC0-CA66388C1533}
(2)HKEY_LOCAL_MACHINESOFTWAREMicrosoftVisualStudio9.0DataProviders{7C602B5B-ACCB-4acd-9DC0-CA66388C1533}
64位操作系统
(1) HKEY_LOCAL_MACHINESOFTWAREWow6432NodeMicrosoftVisualStudio10.0DataProviders{7C602B5B-ACCB-4acd-9DC0-CA66388C1533}
(2)HKEY_LOCAL_MACHINESOFTWAREWow6432NodeMicrosoftVisualStudio9.0DataProviders{7C602B5B-ACCB-4acd-9DC0-CA66388C1533}
再重新试一下,完美解决了。
导入数据模型的时候, 可能导入空的edmx, 然后报这个错:
无法生成模型:“表“TableDetails”中列“IsPrimaryKey”的值为 DBNull。
这是mysql导入EF的一个bug, 解决办法:
在数据库中输入:
use <<database name>>;
set global optimizer_switch='derived_merge=OFF';
后面不用看, 是VS2015的步骤, 重复了N次, 都以失败告终, 别试了.
==========================================================================================================
参考 http://blog.csdn.net/majormayer/article/details/50510223
ADO.NET实体数据模型默认是不支持MySQL数据库的,本文档将介绍如何让VS ADO.NET实体数据模型支持MySQL。
1.下载mysql installer. http://www.mysql.com/why-mysql/windows/visualstudio/
2.安装mysql, 勾选里面的for visual studio插件, 版本不能错:
MySQL Connector/Net(http://dev.mysql.com/downloads/connector/net/)Version:6.9.8 X86
MySQL for VisualStudio(http://dev.mysql.com/downloads/windows/visualstudio/)Version:1.2.5 X86
3.在visual studio中新建一个Asp.net Mvc的项目
4.打开 菜单"工具"->"库程序包管理器"->"程序包管理器控制台",然后在VS工作区域的右下方会出现一个”程序包管理器控制台“命令操作台。
5.输入命令Install-Package EntityFramework
6.上面这个应该已经存在, 再输入 Install-Package MySql.Data.Entity,安装Mysql支持.注意:执行此命令前, 该解决方案的引用里不能有其它版本的MySql.Data.Entity.EF6包, 否则会发生异常
7.安装好了之后,这儿我们需要注意一个问题,Web.config下面的节点自动生成是有问题的,
搜索mysql的provider这个尖括号,
把
<provider ................></provider>
改为
<provider ................/>
8.重启解决方案, powerShell出现报错:
无法加载文件 C:\Users\yangyiru\Documents\Visual Studio 2015\Projects\webTestForMysql\packages\EntityFramework.6.1.3\tools\init.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 http://go.microso
ft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。
这是因为当前执行策略为限制性策略, 不允许执行没有签名的脚本.
get-executionpolicy 这个命令查看当前策略
若要在本地计算机上运行您编写的未签名脚本和来自其他用户的签名脚本,请使用以下命令将计算机上的
执行策略更改为 RemoteSigned:
set-executionpolicy remotesigned
但在win7/win8/win10下,必须使用管理员的权限启动命令命令行,否则会报“Set-ExecutionPolicy : 对注册表项“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\PowerShell\1\ShellIds\Microsoft.PowerShell”的访问被拒绝。”错误。
所以,必须以管理员身份运行visual studio
再执行set-executionpolicy remotesigned
设置完后, 启动项目, 不再报错了
9.测试, 新建ADO.NET实体数据, 可以导入mysql数据库了
VS+mysql+EF搭建的更多相关文章
- .NET Core1.1+VS2017RC+MySQL+EF搭建多层Web应用程序
先贴上解决方案截图 一.新建4个解决方案文件夹 1-Presentation 2-Application 3-Domain 4-Infrastructure 二.在解决方案文件夹中分别创建项目 其余项 ...
- 十二个 ASP.NET Core 例子——1.1版本 EF MySql快速搭建
core1.0的时候搭建过一次mysql EF. 一大推问题.最近在core1.1 又重新搭了一次.简单搭建还挺快,没出现什么幺蛾子.总结下步骤 建立项目,例如ASP.NET Core1.1 WebA ...
- Linux CentOS 安装MySql以及搭建MySql主从复制
前言 在之前的博客中,有过几篇都写了关于mysql在linux下的搭建教程,可能以后还会再写,但是又不想重复在写, 于是便想单独将此抽出来,单独写成一篇博客,并详细记录一些安装过程以及遇到的问题解决办 ...
- Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境搭建教程
原文地址:http://www.osyunwei.com/archives/7378.html 搬运是为了自己找资料方便. 准备篇 一.环境说明: 操作系统:Windows Server 2012 R ...
- django+nginx+xshell简易日志查询,接上<关于《rsyslog+mysql+loganalyzer搭建日志服务器<个人笔记>》的反思>
纠正一下之前在<关于<rsyslog+mysql+loganalyzer搭建日志服务器<个人笔记>>的反思>中说到的PHP+MySQL太慢,这里只是说我技术不好,没 ...
- 关于《rsyslog+mysql+loganalyzer搭建日志服务器<个人笔记>》的反思
关于<rsyslog+mysql+loganalyzer搭建日志服务器<个人笔记>>的反思--链接--http://www.cnblogs.com/drgcaosheng/p/ ...
- Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境搭建教程
准备篇 一.环境说明: 操作系统:Windows Server 2012 R2 PHP版本:php 5.5.8 MySQL版本:MySQL5.6.15 二.相关软件下载: 1.PHP下载地址: htt ...
- mysql 主从搭建步骤
mysql 主从搭建步骤 1:主库开启master端bin-log 2:主库创建备份用户 3:主库全备 4:从库导入全备数据 5:从库修改change master to信息 6:从库slave st ...
- EF搭建可扩展菜单
EF实现可扩展性菜单 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !impo ...
随机推荐
- 自己做的roguelike+恶魔城游戏《魔塔猎人》已发布。
游戏仍然是标准的roguelike,死亡后回到出生点重新开始,宏观架构上参考了<死亡细胞>,战斗设计上更加强调轻重攻击的组合,再配合236和28系列的搓招技.空中的突进飞腿.副武器等等. ...
- 深入理解JavaScript中的函数操作——《JavaScript忍者秘籍》总结
匿名函数 对于什么是匿名函数,这里就不做过多介绍了.我们需要知道的是,对于JavaScript而言,匿名函数是一个很重要且具有逻辑性的特性.通常,匿名函数的使用情况是:创建一个供以后使用的函数.简单的 ...
- 一个简单的java回调函数的实现
回调函数 回调函数涉及的3个函数 登记回调函数 回调函数 响应回调函数 简单的解释 你到一个商店买东西,刚好你要的东西没有货,于是你在店员那里留下了你的电话.过了几天店里有货了,店员就打了你的电话,然 ...
- SqlServer--百度百科
SQL是英文Structured Query Language的缩写,意思为结构化查询语言.SQL语言的主要功能就是同各种数据库建立联系,进行沟通.按照ANSI(美国国家标准协会)的规定,SQL被作为 ...
- 【Java】Java_01初步
1.编程语言的发展史和发展主线 计算机语言如果你将它当做一个产品,就像我们平时用的电视机.剃须刀.电脑.手机等, 他的发展也是有规律的. 任何一个产品的发展规律都是:向着人更加容易使用.功能越来越强大 ...
- JavaScript在IE浏览器和Firefox浏览器中的差异总结
JavaScript在IE浏览器和Firefox浏览器中存在一些差异,以下对这些差异部分进行了总结,以及解决方案: 1.HTML对象的 id 作为对象名的问题 IE:HTML 对象的 ID 可以作为 ...
- Visual Studio提示“无法启动IIS Express Web服务器”或者“无法连接Web服务器IIS Express ”的解决方法
解决办法:找到程序根目录,删除隐藏的.vs文件夹即可. 问题原因:一般是项目拷贝或者系统设置变更所造成的.
- MySQL学习总结(四)数据的基本操作以及MySQL运算符和常用函数
数据库是存储数据库对象的仓库,数据库的基本对象是表,表用来存储数据.关于数据的操作也就是我们常说的CRUD,C指的是CREATE(插入数据记录).R指的是READ(查询数据记录).U指的是UPDATE ...
- cordova开发自己定义插件
以下是自己定义cordova插件的基本入门.做插件的小白可以參考一下哈,兴许会更新插件的进阶博客,希望大家可以共同学习共同进步 1.环境搭建 cordova插件开发前须要安装一些软件和配置环境 1.1 ...
- 使用Nginx的proxy_cache缓存功能取代Squid(转)
Nginx从0.7.48版本开始,支持了类似Squid的缓存功能.这个缓存是把URL及相关组合当作Key,用md5编码哈希后保存在硬盘上,所以它可以支持任意URL链接,同时也支持404/301/302 ...