EFCore 2.1出来有一段时间了,里面的新功能还没怎么用,今天研究下如何使用EF Core 2.1添加种子数据。

这部分的官方文档地址是:https://docs.microsoft.com/en-us/ef/core/modeling/data-seeding

我们在开发时总是需要添加一些种子数据的,所以这个功能还是比较有用的。

准备工作

我建立了一个ASP.NET Core项目,里面有几个Model,其中一个是省份Province,另一个是城市City:

里面还涉及到其它的Model,不过本文用不到,就不贴了。

该项目使用的数据库是MSSQL LocalDB。并已经做好了上述Models的迁移工作。

该数据库里面存在过一些数据,但是现在都被我删除了。

添加第一个种子数据

直接在DBContext的OnModelCreating方法里使用HasData()方法:

这里我添加了一个省份的种子数据,并写上了主键Id的值

数据库该表的主键Id是int自增的。Id为1的数据曾经存在过,但是被我删除了。

然后看看会发生什么

生成的迁移类

命令:Add-Migration Xxx

看一下生成的迁移类的内容:

生成的SQL脚本

命令:Script-Migration

这是里面关于插入数据的部分:

迁移到数据库

命令:Update-Database -Verbose

结果是成功的。

看红线那两句话,EFCore在执行的过程中临时更改了设置,可以插入主键的值,然后又禁用了插入主键。

数据库里面的数据

虽然曾经存在过Id为1的数据(然后被删除了),但是Id为1的种子数据仍然可以插入进去。

种子数据的主键必须有值

我再添加一个没有主键Id值的种子数据:

然后Add-Migration,看看会发生什么:

报错了,所以主键值是必填的。

当我填写了主键值之后,一切都是好用的了:

更改现有的种子数据

我在HasData方法里更改了现有的种子数据,但是主键的值并没有改:

执行Update-Database时的SQL语句:

可以看到是根据主键对数据库里面的数据进行Update动作。

其结果也和我想的一样,就是更新了现有的数据:

如果我把HasData里种子数据的主键值修改了

我把四川的主键从2改为3。

看下生成的迁移文件:

先删除了之前添加的Id为2的种子数据,然后把插入了一笔Id为3的数据。

看下SQL:

也是先Delete,再Insert。

数据库里:

种子数据为什么要指定主键的值?

 因为在团队开发时,这样可以确保不同的开发人员、电脑、服务器上,在同一个迁移版本具有相同的种子数据

添加关联种子数据

Province和City是一对多的关系,也就是说一个Province可以有多个City,而且它们之间有导航属性。

下面看看一次性添加Province和City是否可以行,我直接在HasData方法里这样写:

然后Add-Migration

这样做不行。我必须单独添加City的种子数据,并且设置好外键

所以正确的做法是:

这次Add-Migration没有报错,迁移也成功了,看一下最后的数据:

OK

如果无法在Model里设置主键/外键

有时,我们在主从关系的Model里不明确定义外键;有时候我们Model的主键是private set的;

这时我们就无法在HasData里设置主键/外键的值了,那么如何来添加种子数据呢?

答案就是使用匿名类

我把City Model里的外键去掉(导航属性仍然保留,和Province的主从关系依然存在):

然后就可以这样添加种子数据:

迁移后的数据:

结果仍然如预期一样。

如果主键是Guid类型呢?

看下数据:

貌似没问题。

如果我不修改这个种子数据,再执行一次迁移呢?

看一下这时的迁移文件:

删除原来的数据,再插入一个新的数据。。

数据库里也是这样的:

所以最好的办法是把Guid的值放在一个变量里

然后再操作一遍:

这样就不会出现“把原有数据删掉,再重新插入”这种操作了。

其它

使用context.Database.EnsureCreated()会创建一个新的数据库,并包含有种子数据。但是如果数据库已经存在了,那么EnsureCreated()不会更新数据库,也不会添加种子数据了。

Entity Framework Core 2.1,添加种子数据的更多相关文章

  1. Entity Framework Core 导航属性 加载数据

    Loading Related Data https://docs.microsoft.com/en-us/ef/core/querying/related-data Eager loading me ...

  2. UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?

    选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...

  3. Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 更新关系数据

    Updating related data¶ 7 of 7 people found this helpful The Contoso University sample web applicatio ...

  4. Working with Data » Getting started with ASP.NET Core and Entity Framework Core using Visual Studio » 读取关系数据

    Reading related data¶ 9 of 9 people found this helpful The Contoso University sample web application ...

  5. 在Apworks数据服务中使用基于Entity Framework Core的仓储(Repository)实现

    <在ASP.NET Core中使用Apworks快速开发数据服务>一文中,我介绍了如何使用Apworks框架的数据服务来快速构建用于查询和管理数据模型的RESTful API,通过该文的介 ...

  6. ASP.NET Core 入门教程 8、ASP.NET Core + Entity Framework Core 数据访问入门

    一.前言 1.本教程主要内容 ASP.NET Core MVC 集成 EF Core 介绍&操作步骤 ASP.NET Core MVC 使用 EF Core + Linq to Entity ...

  7. Entity Framework Core系列之DbContext(添加)

    上一篇我们介绍了Entity Framework Core系列之DbContext,对DbContext有了概念上的了解,这篇将介绍DbContext添加数据 通过DbContext添加实体的主要方法 ...

  8. ASP.NET CORE系列【六】Entity Framework Core 之数据迁移

    原文:ASP.NET CORE系列[六]Entity Framework Core 之数据迁移 前言 最近打算用.NET Core写一份简单的后台系统,来练练手 然后又用到了Entity Framew ...

  9. ASP.NET Core 入门笔记9,ASP.NET Core + Entity Framework Core 数据访问入门

    一.前言 1.本教程主要内容 ASP.NET Core MVC 集成 EF Core 介绍&操作步骤 ASP.NET Core MVC 使用 EF Core + Linq to Entity ...

随机推荐

  1. Extjs 上传文件 IE不兼容的问题[提示下载保存]

    我最不喜欢的浏览器的是IE,但无奈很多项目的客户使用的是IE. 在使用Extjs做文件上传时,其他浏览器没有问题,但IE却一个劲提示保存文件,看服务端运行,它其实是运行成功了已经,但客户端的进度条却一 ...

  2. 超实用的JavaScript代码段 Item3 --图片轮播效果

    图片轮播效果 图片尺寸 统一设置成:490*170px; 一.页面加载.获取整个容器.所有放数字索引的li及放图片列表的ul.定义放定时器的变量.存放当前索引的变量index 二.添加定时器,每隔2秒 ...

  3. 怎样在Ubuntu中设置环境变量

    首先启动终端. 单击屏幕左上角的Ubuntu图标,在弹出的窗口中点击搜索栏,输入"terminal", 稍等片刻,终端就会赫然在目!二话不说,直接点击!     然后打开环境设置文 ...

  4. Python 模块详解及import本质

    同在当前目录下的模块和包导入 模块定义 本质就是.py结尾的python文件. 用来从逻辑上组织python代码(变量,函数,类,逻辑) 文件名: test.py;  对应的模块名 : test 模块 ...

  5. Python中的r+和a+

    问题描述 我打算更改文件user_list2中的内容, 本来的想法是加一个temp 文件. 先把user_list2的内容读取并修改后写入temp, 之后再写回来. 但是在读取内容并修改后写入temp ...

  6. eclipse下搭建hibernate5.0环境

    hibernate引入的jar包:hibernate-release-5.0.12.Final.zip 数据库驱动:mysql-connector-java-5.1.46 二.安装hibernate插 ...

  7. java集合框架之HashMap

    参考http://how2j.cn/k/collection/collection-hashmap/365.html#nowhere HashMap的键值对 HashMap储存数据的方式是-- 键值对 ...

  8. Caffe初学者第一部:Ubuntu14.04上安装caffe(CPU)+Python的详细过程 (亲测成功, 20180524更新)

    前言: 最近在学习深度学习,最先要解决的当然是开源框架的环境安装了.之前一直在学习谷歌的Tensorflow开源框架,最近实验中需要跟别人的算法比较,下载的别人的代码很多都是Caffe的,所以想着搭建 ...

  9. 用Fundebug插件记录网络请求异常

    在服务端,不管我们使用Node.js.Java.PHP还是Python等等,都会用日志以文本的形式记录请求以及报错信息.这个对于后端做事后分析是很有用的. 另一方面,前端有时候出问题其实是因为后端接口 ...

  10. 学习JVM是如何从入门到放弃的?

    前言 只有光头才能变强 JVM在准备面试的时候就有看了,一直没时间写笔记.现在到了一家公司实习,闲的时候就写写,刷刷JVM博客,刷刷电子书. 学习JVM的目的也很简单: 能够知道JVM是什么,为我们干 ...