设为首页 收藏本站
查看: 750|回复: 0

[经验分享] MySql 使用 EF Core 2.0 CodeFirst、DbFirst、数据库迁移(Migration)介绍及示例

[复制链接]

尚未签到

发表于 2017-12-11 19:13:34 | 显示全部楼层 |阅读模式
  dotnet core 2.0 发布已经好几天了,期间也把原来 dotnet core 1.1 的 MVC 项目升级到了 2.0,升级过程还是比较顺利的,变动也不是太多。升级的过程中也少不了 Entity Framwork Core 的升级,在这篇文章中主要介绍下 MySql 数据库使用 Entity Framwork Core 2.0 如何进行 Code First、Database First 及数据库迁移(Migration),虽然比较基础,但是做到尽量详细。本文所有示例代码已经提交到 GitHub:https://github.com/starts2000/EFCoreDemo,如果觉得对你有帮助,就给个 Star 吧。

一、工具及环境


  • Visual Studio 2017 15.3
  • .NET CORE 2.0 SDK
二、Entity Framwork Core 2.0 MySql Code First 及 数据库迁移(Migration)

1、创建 .NET Core 类库项目 【Starts2000.EFCoreCodeFirst】

2、添加 User 实体类
  

    public>
{  

public int>
  
[MaxLength(
32), Required]  

public string Aaccount { get; set; }  

  
[MaxLength(
32), Required]  

public string Password { get; set; }  
}
  

  最终【Starts2000.EFCoreCodeFirst】项目结构如下:
DSC0000.png


3、创建 .NET Core 控制台应用项目 【Starts2000.EFCoreCodeFirst.Test】


  • 添加对 【Starts2000.EFCoreCodeFirst】项目的引用;
  • Nuget 添加 Microsoft.EntityFrameworkCore.Tools 及 Pomelo.EntityFrameworkCore.MySql(注意勾上:包括预发行版) 的引用;
4、编辑 Starts2000.EFCoreCodeFirst.Test.csproj 项目文件,添加如下内容:
  

<ItemGroup>  
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
  
</ItemGroup>
  

  最终内容如下:
  

<Project Sdk="Microsoft.NET.Sdk">  

  
<PropertyGroup>
  
<TargetFramework>netcoreapp2.0</TargetFramework>
  
<ApplicationIcon />
  
<OutputType>Exe</OutputType>
  
<StartupObject />
  
</PropertyGroup>
  

  
<ItemGroup>
  
<ProjectReference Include="..\Starts2000.EFCoreCodeFirst\Starts2000.EFCoreCodeFirst.csproj" />
  
</ItemGroup>
  

  
<ItemGroup>
  
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="2.0.0" />
  
<PackageReference Include="Pomelo.EntityFrameworkCore.MySql" Version="2.0.0-rtm-10058" />
  
</ItemGroup>
  

  
<ItemGroup>
  
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
  
</ItemGroup>
  

  
</Project>
  


5、添加 TestDbContext 类(注意:把数据库连接字符串修改为自己的
  

    public>
{  

public DbSet<User> User { get; set; }  

  

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)  
{
  
optionsBuilder.UseMySql(
  

"server=localhost;database=TestDb;user=test;password=123456;");  
}
  

  

protected override void OnModelCreating(ModelBuilder modelBuilder)  
{
  

base.OnModelCreating(modelBuilder);  

//modelBuilder.Entity<User>().HasIndex(u => u.Aaccount).IsUnique();  
        }
  
}
  


6、打开命令行窗口,切换到 【Starts2000.EFCoreCodeFirst.Test】项目文件夹目录,执行如下命令:
  

dotnet ef migrations add InitialCreate  

DSC0001.png

  如果命令执行成功,可以看到项目目录中新增了如下内容:
DSC0002.png


7、执行 dotnet ef database update  命令
DSC0003.png

  执行成功后,可以看到数据库及表创建成功。
DSC0004.png


8、修改实体,并把修改的内容更新到数据库
  User 类的 Account 属性对应 User 表的 Account 列应该是唯一的,前面忘记了设置唯一索引,现在在 TestDbContext 中加上:
  

    public>
{  

public DbSet<User> User { get; set; }  

  

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)  
{
  
optionsBuilder.UseMySql(
  

"server=localhost;database=TestDb;user=test;password=123456;");  
}
  

  

protected override void OnModelCreating(ModelBuilder modelBuilder)  
{
  

base.OnModelCreating(modelBuilder);  
modelBuilder.Entity
<User>().HasIndex(u => u.Aaccount).IsUnique();  
}
  
}
  

  执行 dotnet ef migrations add UserTableUpdateAccount 命令:
DSC0005.png

  如果命令执行成功,可以看到项目目录中新增了如下内容:
DSC0006.png

  接着按照 步骤7 的操作,如果成功,可以看到 User 表已经创建了 Account 的唯一索引:
DSC0007.png


9、测试数据写入和读取
  在 Main 函数中添加如下代码:
  

        static void Main(string[] args)  
{
  

using(var context = new TestDbContext())  
{
  
context.User.Add(
new Models.User  
{
  
Aaccount
= "CodeFirst-Test-" + DateTime.Now.ToString("yyyyMMddHHmmssfff"),  
Password
= "123456"  
});
  

  
context.SaveChanges();
  

  
Console.WriteLine(context.User
  
.OrderByDescending(u
=> u.Id)  
.FirstOrDefault()
?.Aaccount);  
}
  

  
Console.ReadKey();
  
}
  

  把【Starts2000.EFCoreCodeFirst.Test】项目设置为启动项目,编译运行:
DSC0008.png


三、Entity Framwork Core 2.0 MySql Database First

1、新建 【Starts2000.EFCoreDbFirst】 项目

2、Nuget 添加 Pomelo.EntityFrameworkCore.MySql(注意勾上:包括预发行版) 的引用;

3、编辑 Starts2000.EFCoreDbFirst.csproj 项目文件,添加如下内容:
  

  <ItemGroup>  
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
  
</ItemGroup>
  

  最终内容如下:
  

<Project Sdk="Microsoft.NET.Sdk">  

  
<PropertyGroup>
  
<TargetFramework>netcoreapp2.0</TargetFramework>
  
</PropertyGroup>
  

  
<ItemGroup>
  
<PackageReference Include="Pomelo.EntityFrameworkCore.MySql" Version="2.0.0-rtm-10057" />
  
</ItemGroup>
  

  
<ItemGroup>
  
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
  
</ItemGroup>
  

  
</Project>
  


4、打开命令行窗口,切换到 【Starts2000.EFCoreDbFirst】项目文件夹目录,执行如下命令:
  

dotnet ef dbcontext scaffold "Server=localhost;User>  

  执行成功后,项目增加了如下内容:
DSC0009.png


5、创建 .NET Core 控制台应用项目 【Starts2000.EFDbFirst.Test】进行测试


  • 添加对 【Starts2000.EFCoreDbFirst】项目的引用;
  • 把 Main 函数修改为如下代码:
  

        static void Main(string[] args)  
{
  

using (var context = new TestDbContext())  
{
  
context.User.Add(
new User  
{
  
Aaccount
= "DbFirst-Test-" + DateTime.Now.ToString("yyyyMMddHHmmssfff"),  
Password
= "123456"  
});
  

  
context.SaveChanges();
  

  
Console.WriteLine(context.User
  
.OrderByDescending(u
=> u.Id)  
.FirstOrDefault()
?.Aaccount);  
}
  

  
Console.ReadKey();
  
}
  



  • 把【Starts2000.EFCoreDbFirst.Test】项目设置为启动项目,编译运行:
DSC00010.png

  参考文章:


  • https://docs.microsoft.com/en-us/aspnet/core/data/ef-mvc/migrations
  • https://github.com/PomeloFoundation/Pomelo.EntityFrameworkCore.MySql

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-423092-1-1.html 上篇帖子: MySQL之基本语句 下篇帖子: mysql的并发处理机制_下篇
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表