通过EntityFramework来操作MySQL数据库
自己首次用到了EF,为了利人利己,故将自己今天学的记录下来。
这个项目要用到的工具是VS2015、MySQL5.7.12 。
首先我们先建一个解决方案,里面建两个项目分别是Silentdoer.Main和Silentdoer.EfProj
其中Silentdoer.Main是控制台项目,用于执行操作MySQL的代码。
而Silentdoer.EfProj是类库项目,里面将添加ADO.NET 实体数据模型。
我们现在在Silentdoer.EfProj中添加一个ADO.NET 实体数据模型,这个模型对象是数据库和C#程序沟通的“桥梁”,数据表的数据可以通过这个“桥梁”直接在C#中操作(用LINQ会很方便),类似操作List<T>对象一样。新建过程如图:
其中DbForTest是我的MySQL数据仓库(Schema)的名字。(顺便提一下,Windows下MySQL默认Schema和数据表是不区分大小写的,最好将它设置为区分大小写,否则生成的类名字不合规范,当然我这次也没设置)。
设置方式:将lower_case_table_names设置为2
点击添加后来到第二步:
这里选择第一个就好。
点击下一步来到第三步:
这一步要注意,这里右上角新建的连接能且只能定位到一个Schema,一个Model不能同时访问两个数据仓库。这也是我前面为什么用DbForTestModel作为名字的原因(DbForTest是Schema/数据仓库名称),
新建连接时注意选择正确的数据源。
下面的连接字符串是否包含敏感数据(如密码),我为了偷懒直接选了是(如果这个是供服务端用选是一般也没关系),如果选择否的话,则当要用这个Model对象操作数据表之前需要先执行(schMdl是Model对象):
var schMdl = new DbForTestEntities(); schMdl.Database.Connection.ConnectionString="server=XX;database=XX;uid=XX;pwd=XX";(这种方式我感觉执行的时候貌似挺慢的。也可能是第一次执行会变慢,之后则速度正常。)
下面的将 App.Config 中的连接设置另存为(S):要勾上,否则不能更改下面TextBox中的内容,且生成的Model的类名固定为Entities,这明显没DbForTestEntities直观,且当你这里有多个Schema的Model时也许有啥问题也说不定(个人没测试过)。
接着点击下一步:
这里不知道是不是MySQL不够新的原因,我只能用EF5.0,等以后升级了EF6.x后再看看需不需要更新这篇文章。
点击下一步:
上面选择要在Model中“生成”的数据表,可以只选择一部分数据表,如图dttest和student。
这一步注意勾上:确定所生成对象名称的单复数形式(S) ,比如数据表student在C#程序中会以students的名字来显示,如果以student来代表数据表不能很好的直观的让人理解。
后面两个我个人自己选了默认的勾上(我还没用过它们)。
下面的模型命名空间我在弄好之后测了蛮久都不知道它有什么用,个人暂且认为这个参数没啥用,故我统一都用EfNamespace作为值。
点击完成后DbForTestModel就生成完毕。
生成后Silentdoer.EfProj项目如图(直观的可以看到多了DbForTestModel.edmx、packages.config,App.config中多了一些数据。其实项目中还多出了其它数据):
Model展示图如:
这里的dttest和student都可以改名,方式是对其右键-重构-重命名,然后改成新的名字即可(这里貌似部分大小写[也许和MySQL大小写敏感配置有关],不能从dttest改为Dttest,若要该要先改成其它的名字再改)。
接下来就在Silentdoer.Main项目中以DbForTestModel来操作dttest和student两个数据表中的数据吧:
首先在Silentdoer.Main中添加Silentdoer.EfProj项目的引用,然后在Main函数中写如下代码:
var dbMdl = new DbForTestEntities();
dbMdl.student.Add(new student {ClassName = "yibanna", Name = "woailuo"});
dbMdl.SaveChanges();
但是我这边还不能执行,系统提示要添加一些引用,所幸我的Resharper有提示,我自己按Resharper的提示然后就自动添加了,添加后Silentdoer.Main中也会出现:
packages.config文件,且App.config中也会加入EntityFramework相关的数据。
这时候运行异常提示没有配置连接字符串,我们需要从Silentdoer.EfProj的App.config中拷贝出<connectionStrings>...</connectionStrings>块添加到Silentdoer.Main中的App.config文件的对应位置中。
至此大功告成。运行后student表中会有一条新纪录。
通过EntityFramework来操作MySQL数据库的更多相关文章
- Code First操作Mysql数据库
前面博客也讲了,自己做一个网站,选用的是MVC+EF Code First+MySql+EasyUI,先说下技术选型.一.为什么选择MVC? 因为之前自己做的系统大部分是webForm,MVC的之前也 ...
- PHP操作MySQL数据库5个步骤
PHP操作MySQL数据库一般可分为5个步骤:1.连接MySQL数据库服务器:2.选择数据库:3.执行SQL语句:4.关闭结果集:5断开与MySQL数据库服务器连接. 1.用mysql_connect ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- 转 用C API 操作MySQL数据库
用C API 操作MySQL数据库 参考MYSQL的帮助文档整理 这里归纳了C API可使用的函数,并在下一节详细介绍了它们.请参见25.2.3节,“C API函数描述”. 函数 描述 mysql_a ...
- PHP操作mysql数据库:[2]查询数据听语音
本文主要详细讲解如何使用php语言,对mysql数据库进行查询.添加.删除.更新等操作. 工具/原料 Macromedia Dreamweaver 8 mysql数据库,php语言 一.前言 ...
- JDBC操作MySQL数据库案例
JDBC操作MySQL数据库案例 import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...
- shell脚本操作mysql数据库
shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改.查)等各种操作 mysql -hhostname -Pport -uusername -pp ...
- Java使用Jdbc操作MySql数据库(一)
这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...
- 使用node js 操作 Mysql 数据库
使用node js 操作 Mysql 数据库 http://www.nodejs.org/ //node js 数据库操作 MySQL //使用https://github.com/felixge/n ...
随机推荐
- Openning
In order to imporve my english writing skill and enhance my understanding of programming ,I'm setti ...
- mysql导入导出命令(Linux+Windows)
Linux环境: 壹.首先查看mysql的数据存放路径:ps -ef|grep mysql 贰.进入上述查出的mysql数据存放路径:cd var/lib/mysql (数据存放路径) 叁.导出 ...
- java自动生成entity文件
网上关于自动生成entity文件的代码很多,看了很多代码后,在先辈们的基础上再完善一些功能(指定多个表,全部表). 为了使用方便所以把两个类写在一个java文件中,所以大家可以直接拿这个java文件, ...
- liunx中图形化桌面环境中的脚本编程之——创建文本菜单
整体是通过建立菜单布局,然后根据菜单上的布局建立函数(就是为这些布局实现功能),最后将函数和布局实现逻辑上的相连: 如何建立菜单布局? 整体上是通过打印字符创建出,因此需要使用echo命令,但是有一些 ...
- Nova计算节点安装配置
Nova计算节点安装配置 openstack pike 安装 目录汇总 http://www.cnblogs.com/elvi/p/7613861.html ## Nova计算节点安装配置 #基本配置 ...
- mysql的explain
explain 一般用于分析sql. 如下 [SQL] 纯文本查看 复制代码 ? 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 2 ...
- C语言socket编程----实现UDP通信
TCP/IP协议叫做传输控制/网际协议,又叫做网络通信协议.实际上,它包括上百个功能的协议. 套接字(socket):在网络中用来描述计算机中不同程序与其他计算程序的通信方式. 套接字分为三类; 流式 ...
- MySQL安装(yum、二进制、源码)
MySQL安装(yum.二进制.源码) 目录 1.1 yum安装... 2 1.2 二进制安装-mysql-5.7.17. 3 1.2.1 准备工作... 3 1.2.2 解压.移动.授权... 3 ...
- springboot学习(三)——http序列化/反序列化之HttpMessageConverter
以下内容,如有问题,烦请指出,谢谢! 上一篇说掉了点内容,这里补上,那就是springmvc的http的序列化/反序列化,这里简单说下如何在springboot中使用这个功能. 使用过原生netty ...
- 【docker 一】入门实践、环境部署、基本操作指令、镜像库、数据卷
简述 `docker是如火如荼的容器技术,今后会陆续上传关于微服务技术的学习笔记,希望能和大家一起学习一起分享!` docker环境搭建 1.获取最新版的Docker安装包 $ wget -qO- h ...