使用EntityFramework6连接MySQL
使用EntityFramework6连接MySQL
不是微软的亲儿子这待遇就是不一样,其中的坑可真实不少,第一次连MySQL足足折腾了我大半天。
废话不多说直接开始。
安装MySQL
从官网上下载最新版,下载好以后直接安装就可以了。最新版的MySQL已经包含了所有开发需要的功能(包括MySQL连接器),相信会用MySQL,怎么装应该都没有问题,这里就不啰嗦了。不过有一点值得提醒的是,在选择要安装的内容时记得将所有功能都装上,之后出现问题多半都是哪个模块漏装了。
安装好之后,在开始菜单中找到MySQL Workbench,这是MySQL自带的一款管理工具,个人也比较喜欢,一直用的也都是这个。以前要单独安装,不过现在自带了。
创建数据库
为了演示我先创建一个叫test的数据库,并创建一张学生表Student
使用Entity Framework6 连接MySQL数据库
准备工作都就绪了,接下来我创建一个项目来演示如何连接MySQL数据库。
考虑到有些同学可能并不使用.NET MVC,所以这里我们创建一个控制台项目来演示。别担心,在.NET MVC中,配置的过程都是完全一样的。
一、添加EF包
打开NuGet包管理工具后,点击浏览,然后搜索EntityFramework。先按装EntityFramework,再安装MySQL.Data.Entity.
通过NuGet来安装EF可以帮我们省去很多麻烦的配置环节。
二、通过向导来连接MySQL数据库
按照习惯,我先在项目中建立了一个Modules文件夹,用于保存所有生成的数据模型文件。之后右击,新建项。
之后选择ADO.NET实体数据模型,我取名为DBModel。
选择来自数据库的CodeFirst模型,点击下一步。
PS:EF有三种方式来运行。
第一种是通过EF设计器,类似于传统的数据库设计器,通过画出的数据结构图来生成对应的类(数据模型)和数据库,不过这种方式好像在EF7中将被废弃掉了,所以不推荐使用。
第二种是通过先创建好数据库,然后根据数据库来生成对应的数据模型,这种方式称之为数据库优先DB Frist。
第三种是先手工编写好需要的数据模型,然后根据数据模型逆向生成数据库,这种方式称之为代码优先 Code First。
注意:不管你是习惯数据库优先还是代码优先。都请先用数据库优先来生成代码,这样会省去很多中间配置的环节。
之后选择新建连接
输入你的数据库地址(默认是localhost)和账号、密码,勾选保存密码,在数据库名称中选择你对应的数据库,在这我的是test。完成后点击测试连接,提示没有问题后点击确定。这一步如果出错一般都是数据库配置的问题,跟EF没有关系。
选择,是包含敏感信息
选择你需要的数据库和表,在这我选择的是我之前在数据库中创建的Student表。确定所生产对象名称的单复数形式这个选项随意。最开始我也没理解到它的作用,其实就是英语的单复数,就是在名词后面加S和不加S。
点击完成之后如果你幸运的话,到这一步就成功了。不过事情一般没那么简单,傲娇的EF就提示我什么主键值为空。
我第一次弄的时候这东西折磨了我大半天,什么办法都试尽了,好在最后在Stack Overflow上找到了办法。
打开MySQL管理器,执行
- use `test`; /*你的数据库名*/
- set global optimizer_switch='derived_merge=OFF';
执行完之后再按照上面的步骤从头一遍应该就可以了,如果还是不行就重启一下MySQL服务,再执行一下上面的代码,再试试。
三、分析生成的代码
回到解决方案资源管理器,这时我们的项目下就应当多了两个文件,一个是DBModel数据库上下文(到时都是通过它来操作数据库),一个是student数据模型。
打开DBModel.cs
student数据模型中对数据做了些描述(你不用代码优先CodeFirst这些一般都不用管)
使用EF进行增删改查
到这一步EF连接MySQL就已经完成了,之后你就可以像操作SQL Server一样使用EF操作MySQL了。不过我还是演示下如何使用EF操作数据库。
- class Program
- {
- static void Main(string[] args)
- {
- using (var db = new DBModel())
- {
- var student = (from t in db.students //查询张三
- where t.name == "张三"
- select t).First();
- Console.WriteLine("张三的年龄是:" + student.age); //输出:张三的年龄是:15
- db.students.Remove(student); //删除张三
- //db.Entry(student).State = System.Data.Entity.EntityState.Deleted; //或者这样删除张三
- db }); //向数据库中添加小明
- student = (from t in db.students //查询李四
- where t.name == "李四"
- select t).First();
- student; //更改李四的年龄
- //db.Database.ExecuteSqlCommand("delete from test.student where true"); //执行普通的SQL,删除全部数据
- //var result = db.Database.SqlQuery<student>("select * from test.student"); //执行普通的SQL,查询所有学生
- db.SaveChanges(); //保存结果
- }
- Console.Read();
- }
- }
出处:http://www.cnblogs.com/wujingtao/p/5399950.html
使用EntityFramework6连接MySQL的更多相关文章
- 用EntityFramework6连接MySQL【转】
http://www.cnblogs.com/wujingtao/p/5399950.html 不是微软的亲儿子这待遇就是不一样,其中的坑可真实不少,第一次连MySQL足足折腾了我大半天. 废话不多说 ...
- 使用EntityFramework6连接MySql数据库(db first方式)
准备工具: VS2013.MySQL For VisualStudio 1.1.4.Connector/Net 6.8.3(百度网盘里) 程序包管理器执行命令: Install-Package Ent ...
- 使用EntityFramework6连接MySql数据库(code first方式)
demo托管地址:http://git.oschina.net/uustudy/ASP.NET-CodeFirst-MySQL-Demo.git 之前的是db first(地址:http://www. ...
- 使用EntityFramework6连接MySql数据库
准备工具: VS2013.MySQL For VisualStudio 1.1.4.Connector/Net 6.8.3(百度网盘里) 程序包管理器执行命令: Install-Package Ent ...
- 使用EntityFramework6连接MySql数据库-db first方式
准备工具: VS2013.MySQL For VisualStudio 1.1.4.Connector/Net 6.8.3 程序包管理器执行命令: Install-Package EntityFram ...
- EF 连接MySql
使用EntityFramework6连接MySql数据库(db first方式) http://www.cnblogs.com/24la/archive/2014/04/03/ef6-mysql.ht ...
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
- 【初学python】使用python连接mysql数据查询结果并显示
因为测试工作经常需要与后台数据库进行数据比较和统计,所以采用python编写连接数据库脚本方便测试,提高工作效率,脚本如下(python连接mysql需要引入第三方库MySQLdb,百度下载安装) # ...
- Node.js Express连接mysql完整的登陆注册系统(windows)
windows学习环境: node 版本: v0.10.35 express版本:4.10.0 mysql版本:5.6.21-log 第一部分:安装node .Express(win8系统 需要&qu ...
随机推荐
- AIM Tech Round 3 (Div. 1) (构造,树形dp,费用流,概率dp)
B. Recover the String 大意: 求构造01字符串使得子序列00,01,10,11的个数恰好为$a_{00},a_{01},a_{10},a_{11}$ 挺简单的构造, 注意到可以通 ...
- 『cs231n』作业3问题1选讲_通过代码理解RNN&图像标注训练
一份不错的作业3资料(含答案) RNN神经元理解 单个RNN神经元行为 括号中表示的是维度 向前传播 def rnn_step_forward(x, prev_h, Wx, Wh, b): " ...
- 使用python创建mxnet操作符(网络层)
对cuda了解不多,所以使用python创建新的操作层是个不错的选择,当然这个性能不如cuda编写的代码. 在MXNET源码的example/numpy-ops/下有官方提供的使用python编写新操 ...
- thinkphp3.2导出
public function test() { set_time_limit(0); ini_set('memory_limit', '500M'); //导入PHPExcel类库,因为PHPExc ...
- node搭建本地服务器
随着前端不断发展,node基本已经成为必备,在调试的时候经常需要服务器,在之前的做法通常是去下载一个phpstudy 或者 xampp等启动一个服务,作为一个前端人虽然可以借助各种工具,但是怎么能不懂 ...
- nyoj306 二分+DFS
走迷宫 时间限制:1000 ms | 内存限制:65535 KB 难度:5 描述 Dr.Kong设计的机器人卡多非常爱玩,它常常偷偷跑出实验室,在某个游乐场玩之不疲.这天卡多又跑出来了,在SJ ...
- UVA-12113 Overlapping Squares (回溯+暴力)
题目大意:问能不能用不超过6张2x2的方纸在4x4的方格中摆出给定的图形? 题目分析:暴力枚举出P(9,6)种(最坏情况)方案即可. 代码如下: # include<iostream> # ...
- 5.4 使用 Razor 表达式
以下内容主要展示 Razor 所支持的各种表达式,以及如何用它们来创建视图的内容. 在一个好的 MVC 框架应用程序中,动作方法与视图的作用是清晰.分离的.其规则很简单,如表所示: 组件 要做的事 不 ...
- Python将列表作为栈和队列
Collections中的各种方法 阅读目录(Content) 一.各种方法介绍 二.代码部分 回到顶部(go to top) 一.各种方法介绍 Counter 统计个数 elements mo ...
- Freemaker FTL指令常用标签及语法
https://blog.csdn.net/pengpengpeng85/article/details/52070602 FTL指令常用标签及语法 注意:使用freemaker,要求所有标签必须闭合 ...