CodeFirst+MySql开发简单入门

记录一下使用Mysql进行EF Codefirst方式开发的简单过程。

0.准备工作

安装MySql,mysql-connector-net,mysql-for-visualstudio,这部分网上有很多教程,https://blog.csdn.net/ZKH_101/article/details/52518384

1.新建项目,添加组件

新建一个控制台应用程序,名字为MysqlCodeFirst,Nuget安装MySql.Data.Entity

安装完成后项目会多出来以下几个引用

添加新建项→ADO.NET实体对象模型→空CodeFirst模型,名字为CodeFirstDb,执行完这一步,会改变配置文件并添加一个CodeFirstDb.cs文件

①配置文件如下:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<!-- 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>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1" />
</startup>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="mssqllocaldb" />
</parameters>
</defaultConnectionFactory>
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.10.8.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider>
</providers>
</entityFramework>
<connectionStrings>
<add name="CodeFirstDb" connectionString="data source=(LocalDb)\MSSQLLocalDB;initial catalog=MysqlCodeFirst.CodeFirstDb;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework" providerName="System.Data.SqlClient" />
</connectionStrings>
</configuration>

我们可以看到自动生成的connectionString是连接Ms的,为了连接Mysql我们把connctionStrings改成如下,注意providerName也要切换到Mysql:

 <connectionStrings>
<add name="EntityDb" connectionString="Data Source=.;port=3306;Initial Catalog=CodeFirstDb;user id=root;password=123456;" providerName="MySql.Data.MySqlClient" />
</connectionStrings>

② CodeFirstDb.cs文件修改如下

根据CodeFirst的约定:Id会被设置为主键。

更多约定详见msdn(https://msdn.microsoft.com/zh-cn/data/jj679962)。

2.把MyEntity映射到MySql数据库

1.Enable-Migrations  启动迁移

执行后项目生成Migrations文件夹,在该文件夹有Configuration.cs文件,Configuration.cs文件是迁移的配置类,代码如下seed生成时是一个空方法,我们在seed方法中初始化一条数据:

   internal sealed class Configuration : DbMigrationsConfiguration<MysqlCodeFirst.CodeFirstDb>
{
//构造函数中可以添加一些迁移前的配置
public Configuration()
{
AutomaticMigrationsEnabled = false;
}
//在迁移完成后执行,初始化的数据
protected override void Seed(MysqlCodeFirst.CodeFirstDb context)
{
context.Set<MyEntity>().AddOrUpdate(new MyEntity()
{
Id = ,
Name = "hello ef!"
});
}
}

② Add-Migration FirstInit。(为本次迁移起名字为FirstInit)

此时在项目的Migration文件夹中会自动生成迁移记录文件,文件名以“当前时间_本次迁移的名字”作为类名。

记录文件有一个设计器和一个资源类和一个迁移具体操作的方法,设计器和资源类的内容都是自动维护的,不需要我们操作。

迁移文件类有Up()和Down()两个方法,分别用于升级和降级。我们在修改数据库架构的时候有时候会在这个类型修改配置,代码如下

public partial class firstInit: DbMigration
{
/// <summary>
/// 本次迁移执行的具体操作,即升级数据库。
/// </summary>
public override void Up()
{
//创建架构为"dbo",表名为”MyEntities"的数据库表。
CreateTable(
"dbo.MyEntities",
c => new
{
Id = c.Int(nullable: false, identity: true),//Id,int类型,不可为空,标识列(自动增长)。
Name = c.String(),//Name,string类型
})
.PrimaryKey(t => t.Id);//设置主键为Id }
/// <summary>
/// 以后如果回滚数据库,那么会执行此降级方法。
/// </summary>
public override void Down()
{
DropTable("dbo.MyEntities");//删除架构为"dbo",表名为”MyEntities"的数据库表。
}
}

③ Update-DataBase –script   生成Sql脚本 ,这一步可以不执行的,主要在查错时使用

本例中生成的sql脚本如下:

create table `MyEntities` (`Id` int not null  auto_increment ,`Name` longtext,primary key ( `Id`) ) engine=InnoDb auto_increment=0
create table `__MigrationHistory` (`MigrationId` nvarchar(150) not null ,`ContextKey` nvarchar(300) not null ,`Model` longblob not null ,`ProductVersion` nvarchar(32) not null ,primary key ( `MigrationId`) ) engine=InnoDb auto_increment=0
INSERT INTO `__MigrationHistory`(
`MigrationId`,
`ContextKey`,
`Model`,
`ProductVersion`) VALUES (
'201809070820233_firstInit',
'MysqlCodeFirst.Migrations.Configuration',
0x1F8B0800000000000400CD57DB6EDB38107D5F60FF81E0736AE68262B781DC22759222D83A09AAB4EFB4347688A548551C05D6B7F5A19FB4BFB043EB2ED98E1B144561C0B0C89933670E6786F27FDFBE07EFD689664F903965CD949F4C8E390313D95899D594E7B87CF5377FF7F6CF3F82AB3859B32FB5DD99B7234FE3A6FC11313D17C2458F90483749549459679738896C22646CC5E9F1F11B7172228020386131167CCA0DAA04360FF438B326821473A9E73606EDAA75DA0937A8EC5626E05219C194CF0BF755CFC8EC5A650E39BBD04A128B10F49233698C4589C4F1FCB38310336B56614A0B523F142990DD526A0715F7F3D6FCD0348E4F7D1AA275ACA1A2DCA14D7E10F0E4ACD2450CDD5FA42E6F7423E5AE48612C7CD61BF5BC70E51267C360E7339D79C3A1B893DAE588F5378E9A4AA082F19F2336CB35E6194C0DE498497DC4EEF38556D13F503CD87FC14C4DAE75971F31A4BDDE022DDD6736850C8B4FB0AC58DFC49C89BE9F183A366E1D9F329F1B8367A79CDD5270B9D0D01C7F27F7106D061FC0402611E27B890899F11850A925F6C6F2DF7534AA376A1BCEE672FD11CC0A1F4950B9E6EC5AAD21AE572A069F8DA22E2327CC72E80709447B76E313A55E41A9886E45A03994CBC59693A52EA80ED755A1FAD994982160BF481438CE5A16657B4DDA0ADA46B721D676AF28DBB76E73B1A3CF83B94C5352AED3F7D50A0BCBA69FBD0A7FBC23921243446E4B63346C9B485407720583DDAEBE12E542FAB39BC5C91EB3C52E89EB4823A5875DD00A5FBBF8DFB5DBD60E1D62B4125E535609D5F2264168C874E6C1C8753377A596D996BE9A599D2766576FEEF32E3BA5EB5FAE8C110231E03E14488C141A4C88A1E6FBCA7568D2446FCA76509E41552ACFDF55A3DA294D3823699E54ECEB665E845FF5C4EF4F363F675A51C2ADC55C1AB50487E514E5AF277F0DAEBCDFE7FA11CEC5FAC03BE897DF04CA8BFAECAC1F5D14870F7F4DAF1A086BEC82FCBCD95ECF9E83A677B17776973538E5F1C212F7926877ECBF70B68F9B2210DDD7BCE0129C5AB510FEA5CF40E4ABAD05AD6D6ECCD2D65A537A5D46B5C9E028E6803226952E32544B19216D47E0DCE63EFE22754E2657C902E21B7397639AE38573902C74EF2E0BC4FEF89B0BACCF39B84BFD93FB1929104D4529C09D799F2B1D37BCAFC7A5B80BC2174C55DFC48ADE47086E553448B7D61C0854C977092918DF1D0F90A49AC0DC9D09E513BC841BBD8A7C84958C8A7AB4ED0679FE20FAB207974AAE3299B80AA3F5F77F5D84FFEFF2F67F675569BEED0C0000,
'6.2.0-61023');

第一段创建表MyEntities。

第二段:创建表_MigrationHistory,是EF6框架用来维护模型的表。

  [MigrationId]:遍号,主键,存储设计类中Id,其实就是本次迁移记录的名称。

  [ContextKey]:标记当前上下文的识别码,主键,因为CodeFirst支持多个上下文实例,所以用这个字段来标记。

  [Model]:模型,当前模型的具体描述,加密了。

  [ProductVersion]:EF框架的版本号。

EF6框架通过这张表具体记录每次迁移变化,也是通过这张表来检查程序中的对象和数据库中的关系是否一致。

④ Update-DataBase –verbose(或者-v)。更新数据库并查看sql脚本

然后去看一下数据库,可以看到codefirstdb数据库已经自动生成了,初始化的数据也存入了数据库中

这里采用了最简单的方式实现使用mysql的codefirst开发方式,暂时记录到这里,以后在项目中用到再做进一步记录。

参考文献:

1.https://www.cnblogs.com/kexxxfeng/p/5095812.html

2.https://www.cnblogs.com/summit7ca/p/5423637.html

3.http://www.cnblogs.com/gameman/p/3773240.html

CodeFirst+MySql开发的更多相关文章

  1. EF6(CodeFirst)+MySql开发脱坑指南

    废话 话说当年,在一个春光明媚的晌午,邂逅了迷人的丁香姑娘,从此拜倒在了她的石榴裙下,至今不能自拔,这位丁香姑娘就是ORM思想. 所谓ORM思想,我的理解就是根据一定的规则,把程序中的对象和数据库中的 ...

  2. EF6(CodeFirst)+MySql开发遇到的坑

    最近一不小心偷个懒就已经过了好几个月了,真是惭愧惭愧,出来混终究是要还的,我还是把”脱坑指南“写完吧,-_-~~.点我打开上篇博客 0x001.架构名”dbo”の殇 坑之首也,当提架构名,在mssql ...

  3. C#中缓存的使用 ajax请求基于restFul的WebApi(post、get、delete、put) 让 .NET 更方便的导入导出 Excel .net core api +swagger(一个简单的入门demo 使用codefirst+mysql) C# 位运算详解 c# 交错数组 c# 数组协变 C# 添加Excel表单控件(Form Controls) C#串口通信程序

    C#中缓存的使用   缓存的概念及优缺点在这里就不多做介绍,主要介绍一下使用的方法. 1.在ASP.NET中页面缓存的使用方法简单,只需要在aspx页的顶部加上一句声明即可:  <%@ Outp ...

  4. ASP.NET Core 3.0 WebApi 系列【2】.Net Core 3.0+ CodeFirst + MySql 实现数据的迁移

    写在前面 在前一小节中,我们创建了基于RESFULL风格的服务.这个小节,尝试使用CodeFirst+MySql 的方式实现数据迁移. 一.开发环境 [1]运行环境:win10 家庭版 [2]开发工具 ...

  5. Win7搭建nginx+php+mysql开发环境以及websocket聊天实例测试

    Win7搭建nginx+php+mysql开发环境以及websocket聊天实例测试一.下载相关安装包 1.下载nginx最新版本(nginx1.3.13版之后才支持websocket协议) 下载地址 ...

  6. 深入理解MySQL开发性能优化.pptx

    深入理解MySQL开发性能优化.pptx,依旧上传baidu pan http://pan.baidu.com/s/1jIwGslS,视频暂未出,培训完成后会更新.

  7. 【MySql】赶集网mysql开发36条军规

    [MySql]赶集网mysql开发36条军规 2012-05-14 14:02:33 分类: Linux   写在前面的话: 总是在灾难发生后,才想起容灾的重要性: 总是在吃过亏后,才记得曾经有人提醒 ...

  8. mysql开发中使用存储过程

    在mysql开发中使用存储过程的理由: 当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的 mysql 执行语句是要先编译,然后再执行的.这样如果查询并发大的时候. ...

  9. [转载] 根据多年经验整理的《互联网MySQL开发规范》

    原文: http://weibo.com/p/2304181380b3f180102vsg5 根据多年经验整理的<互联网MySQL开发规范> 写在前面:无规矩不成方圆.对于刚加入互联网的朋 ...

随机推荐

  1. Matplotlib学习---用seaborn画联合分布图(joint plot)

    有时我们不仅需要查看单个变量的分布,同时也需要查看变量之间的联系,这时就需要用到联合分布图. 这里利用Jake Vanderplas所著的<Python数据科学手册>一书中的数据,学习画图 ...

  2. Hdoj 2454.Degree Sequence of Graph G 题解

    Problem Description Wang Haiyang is a strong and optimistic Chinese youngster. Although born and bro ...

  3. 08 Zabbix4.0系统配置事件通知 - 动作Action

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 08 Zabbix4.0系统配置事件通知 - 动作Action 请点击查看Zabbix3.0.8版 ...

  4. Double.valueOf(0.0D) 分析

    private Double price = Double.valueOf(0.0D); 查看Java API 文档如下: doubleValue public double doubleValue( ...

  5. 深挖JDK动态代理(一)

     最近在研究RPC框架,避免不了的就是在RPC调用中使用最多的则是动态代理的机制了,基于此,我们先来研究一下JDK动态代理 我们先来尝试着编写一下JDK动态代理的代码 1. 由于JDK动态代理是基于接 ...

  6. [Splay][学习笔记]

    胡扯 因为先学习的treap,而splay与treap中有许多共性,所以会有很多地方不会讲的很细致.关于treap和平衡树可以参考这篇博客 关于splay splay,又叫伸展树,是一种二叉排序树,它 ...

  7. win32: WM_PAINT 实现双缓冲缓图

    相关参考资料: GDI下实现双缓冲 - http://jingyan.baidu.com/article/e73e26c0f8df2424acb6a76e.html <Win32_19>用 ...

  8. Autotools知识点

    最近研究了下glog使用autotools编译方法的脚本文件,略有所得 configure.ac AC_INIT初始化一些信息 Package Version ReportBug AC_CONFIG_ ...

  9. java的集合

    Collection: 1.list ArrayList.Vector.LinkedList ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构. Vector是 ...

  10. tomcat发布项目,运行不了

    工作中经常出现项目本来运行得好好的,从SVN上面更新代码后就不行了 这个问题有时候是因为编译不成功,处理步骤如下: 1.clean整个项目,重新编译 2.如果还是不行,则把编译中认为是error的设置 ...