前言

最近打算用.NET Core写一份简单的后台系统,来练练手

然后又用到了Entity Framework Core

发现园子里有些文章讲得不是那么细节,对于新手小白来说,可能会有点懵。

特意整理了几个细节.

正文

数据迁移

首先EF CORE跟以前的EF6是有不同点的,

微软官网列出的不同点:https://docs.microsoft.com/zh-cn/ef/efcore-and-ef6/features

安装 EF 核心 NuGet 包

若要使用 EF 核心,请为你想要使用的数据库提供程序安装 NuGet 包。 例如,如果目标 SQL Server,你将安装Microsoft.EntityFrameworkCore.SqlServer

如果你打算使用迁移,则还应安装Microsoft.EntityFrameworkCore.Tools包。

Install-Package Microsoft.EntityFrameworkCore.SqlServer

Install-Package Microsoft.EntityFrameworkCore.Tools

注意:下面的讲解有一部分在前面的文章有出现过,为了照顾没有读前面文章的同学,代码就简单的贴出来。不多做讲解

首先新建一个 Model 类 SysUser:

然后建立EFCoreContext类

自动创建数据库

此时我们的数据库 和数据都已经有了

数据迁移

此时重点来了,当我们已经有数据库表的时候,我们需要修改字段,如何进行迁移

首先打开VS->工具->NuGet包管理器->程序包管理控制台

输入命令:Add-Migration init(执行此命令项目生成一个目录(Migration))

我们会发现Model程序集下多了一个文件夹为Migrations里面有3个文件.如下:

xxxxxxx_init.cs主迁移文件。包含应用迁移(in Up())和恢复(in Down())所需的操作。

xxxxxxx_init.Designer.cs - 迁移元数据文件。包含EF使用的信息。

EFCoreContextModelSnapshot.cs - 当前模型的快照。主要用于确定添加下一次迁移时发生了哪些变化.

然后我们执行命令:

Update-Database

如果你的数据库没创建,是第一次,就会执行成功,


如果你前期创建过数据库.但是是第一次创建迁移..就会失败

果然报错了,提示我们的表结构已经存在了,

我们看看xxxxxx_init.cs文件:

可以看到,这里第一次生成的迁移方法是按照新增来迁移的..而不是修改。

我们把Up()   Down()里面的代码删掉

这样就相当于 本次的迁移,没有做任何操作。

然后我们来创建真正的迁移版本:

首先添加一个Email字段,然后把UserName的长度改为60

然后我们开始迁移..

 Add-Migration  x2 (这里是迁移版本名称,可自定义,可以根据版本回滚)

成功创建迁移文件之后,我们更新数据库.

Update-Database x2

 然后Email字段加上了,UserName长度也修改了,UserName的数据也还在。

删除迁移

的时候我们刚刚创建了一个迁移,还没应用到数据库,就发现自己需要变更实体.那我们就可以删除这个没有应用的迁移版本.

执行命令如下:

 Remove-Migration

注意,这里是没有应用过的迁移,可以删除.如果应用过了.则会收到错误信息

迁移回滚

有些时候,我们需要回滚到之前的一个迁移版本.,比如我们部署的时候,开发版本和稳定版本肯定不一样..

那么我们就会用到回滚命令.

执行如下: 

Update-Database  这里填写需要回滚的版本名称

我们执行  Update-Database init   

然后我们会发现, x2中的长度已经回到30了,Email字段也没有了....

生成迁移SQL

有的时候,我们的生产数据库,是需要用脚本来创建库的.所以我们也可以直接通过实体来生成SQL脚本.命令如下:

 Script-Migration

举一反三:Script-Migration x2  这个脚本可以自定义需要迁移的版本号.文件名,需要生成迁移脚本的上下文

ASP.NET CORE系列【六】Entity Framework Core 之数据库迁移的更多相关文章

  1. 使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序

    使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序 不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻 ...

  2. Working with Data » 使用Visual Studio开发ASP.NET Core MVC and Entity Framework Core初学者教程

    原文地址:https://docs.asp.net/en/latest/data/ef-mvc/intro.html The Contoso University sample web applica ...

  3. 【ASP.NET Core学习】Entity Framework Core

    这里介绍在ASP.NET Core中使用EF Core,这里数据库选的是Sql Server 如何使用Sql Server 添加模型 && 数据库迁移 查询数据 保存数据 如何使用Sq ...

  4. Asp.net Mvc Entity Framework Code First 数据库迁移

    1.创建Mvc项目 2.安装Entity Framework 2.1.如下图打开程序包管理器控制台: 2.2.输入命令Install-Package EntityFramework,即可安装Entit ...

  5. 手把手教你ASP.NET Core:使用Entity Framework Core进行增删改查

    新建表Todo,如图 添加模型类 在"解决方案资源管理器"中,右键单击项目. 选择"添加" > "新建文件夹". 将文件夹命名为 Mo ...

  6. Asp.net Core中使用Entity Framework Core CodeFirst

    1.安装对应的包 "Microsoft.EntityFrameworkCore.Design": "1.1.0", "Microsoft.Entity ...

  7. ABP 教程文档 1-1 手把手引进门之 ASP.NET Core & Entity Framework Core(官方教程翻译版 版本3.2.5)

    本文是ABP官方文档翻译版,翻译基于 3.2.5 版本 官方文档分四部分 一. 教程文档 二.ABP 框架 三.zero 模块 四.其他(中文翻译资源) 本篇是第一部分的第一篇. 第一部分分三篇 1- ...

  8. 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 ...

  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 ...

  10. NET Core & Entity Framework Core

    ABP 教程文档 1-1 手把手引进门之 ASP.NET Core & Entity Framework Core(官方教程翻译版 版本3.2.5)   本文是ABP官方文档翻译版,翻译基于 ...

随机推荐

  1. table 表格的增删和修改

    如上图,图片的增删都没有问题:唯一的问题就是我改变下一行的内容时,把上面一行给覆盖了,费了好久,终于找到原因了,直接贴代码: 效果如下:

  2. 从零部署Spring boot项目到云服务器(准备工作)

    自己的博客终于成功部署上线了,回过头来总结记录一下整个项目的部署过程! 测试地址:47.94.154.205:8084 注:文末有福利! 一.Linux下应用Shell通过SSH连接云服务器 //ss ...

  3. 用 Go 编写一个简单的 WebSocket 推送服务

    用 Go 编写一个简单的 WebSocket 推送服务 本文中代码可以在 github.com/alfred-zhong/wserver 获取. 背景 最近拿到需求要在网页上展示报警信息.以往报警信息 ...

  4. JavaScript(第十天)【Function类型】

    在ECMAScript中,Function(函数)类型实际上是对象.每个函数都是Function类型的实例,而且都与其他引用类型一样具有属性和方法.由于函数是对象,因此函数名实际上也是一个指向函数对象 ...

  5. 连接数据后,当执行查询语句报错:ORA-01219: 数据库未打开: 仅允许在固定表/视图中查询

    参考博客:http://blog.csdn.net/lanchengxiaoxiao/article/details/40982771 1.在cmd窗口通过sqlplus连接数据库 C:\Users\ ...

  6. [福大软工] W班 软工实践原型设计—成绩公布

    作业地址 https://edu.cnblogs.com/campus/fzu/FZUSoftwareEngineering1715W/homework/909 作业要求 详见作业地址 存在问题 1. ...

  7. Alpha冲刺总结

    团队成员 陈家权 031502107 赖晓连 031502118 雷晶 031502119 林巧娜 031502125 庄加鑫 031502147 一.项目预期计划及现实进展 项目预期计划 现实进展 ...

  8. 4c语言的第0次作业

    1.你认为大学的学习生活.同学关系.师生关系应该是怎样? 我认为大学的学习生活应该是充实有意义的,有对学习的激情又有与伙伴相知的愉悦. 我认为同学关系应该是互相尊重,互相学习,坦诚相待. 我认为师生关 ...

  9. python 继承基础

    class annamal: def chi(self): print(self.name + '吃') def he(self): print(self.name + '喝') class dog( ...

  10. 【作业】HansBug的前三次OO作业分析与小结

    OO课程目前已经进行了三次的作业,容我在本文中做一点微小的工作. 第一次作业 第一次作业由于难度不大,所以笔者程序实际上写的也比较随意一些.(点击就送指导书~) 类图 程序的大致结构如下: 代码分析 ...