ASP.NET Core 8.0学习笔记(二十七)——数据迁移:Migrations深入与其他迁移命令

一、数据库架构的管理

1.EF Core提供两种方式来保持EF Core的模型与数据库保持同步。

(1)以数据库为准:反向工程(Db First),适用于中大型工程

(2)以代码为准:数据迁移(Code First),适用于小型工程

2.关于Nuget包:Microsoft.EntityFrameworkCore.Design:常用于反向工程 Tools:数据迁移

3.迁移方式:

(1)当引入的数据模型更改时,添加迁移操作时,EF Core将当前模型与旧模型的快照进行比较,确定差异并生成迁移源文件

注意:主要是比较模型类与模型配置类(IEntityTypeConfiguration接口实现类以及DbContext类)修改前后的差异(修改前的代码保存在快照当中),然后生成对应的迁移脚本

(2)生成新的迁移后,迁移的记录将保存在Migration文件夹中。EF也将在数据库中记录所有的迁移变化

二、深入研究Migrations中的两个方法

1.获取Migrations脚本:新建实体类与配置类,以及DbContext,然后执行数据库迁移指令,观察生成的数据库脚本:

实体模型:

配置类:

数据库上下文类:

执行数据库迁移指令:

生成的Migration脚本如下:

2.引入概念:

(1)向上迁移、向下迁移:使用迁移脚本,可以对当前连接的数据库执行编号更高的迁移,这个操作叫做向上迁移(Up),也可以执行将数据库回退到旧的迁移,这个操作称为"向下迁移"。

(2)注:除非有特殊需要,否则不要删除Migrations文件夹下的代码(回退数据库版本使用)

3.代码分析:

(1)根目录下的文件

(2)Intial.cs的Up与Down方法:

Up:生成这张表或执行更新操作所需要的代码脚本

Down:回退当前操作所需要执行的代码

若在实体中添加一个属性Height,同样执行数据库迁移命令,生成的脚本如下:

注意,在生成的数据库中会有一张表,用于记录Migration记录,若随意删除则会报错。

4.但是Migration文件夹中的文件也不是一定不能删除。一般情况下只需要将生成的数据库整个删除以后,再删掉Migrations文件夹即可。此时重新运行Add-Migration命令以及update-database就不会出现任何问题。(因为快照等都被删除了,等于重新开始建库)

三、其他的Migration迁移指令

1.Update-Database XXX:将数据库回滚到XXX的状态,迁移脚本不动

将数据库回滚到Initial状态

2.删除最后一次的迁移脚本:Remove-Migration

3.Script-Migration:生成迁移Sql代码。Update-Database可以更新数据库,执行该命令可以生成SQL的更新脚本,手动更新数据库,有利于DBA对数据库进行管理以及恢复。

五、重置迁移

1.若需要重置所有迁移,但是又需要保留测试数据,可以按照以下方法操作:

(1)删除Migrations文件夹

(2)删除对应数据库中__EFMigrationsHistory表中的数据(不是删除表,只是清除数据)

(3)创建新的迁移并为其生成SQL脚本

(4)在数据库的迁移记录表(__EFMigrationsHistory)中插入一行,以记录刚才的迁移已经应用

2.示例:

(1)删除Migrations文件夹,重新执行Migration:

(2)删除数据库中的__EFMigrationHistory表中的数据

(3)将迁移的脚本所产生的数据直接插进迁移记录表中:(相当于手动执行update-database)

(4)修改一下代码,重新应用迁移:将People表的Name属性的最大长度由50改为64:

查看数据库:

且其他表的数据都没有受到影响。

相关推荐
数据智能老司机3 小时前
CockroachDB权威指南——CockroachDB SQL
数据库·分布式·架构
数据智能老司机3 小时前
CockroachDB权威指南——开始使用
数据库·分布式·架构
“抚琴”的人3 小时前
【机械视觉】C#+VisionPro联合编程———【六、visionPro连接工业相机设备】
c#·工业相机·visionpro·机械视觉
松果猿4 小时前
空间数据库学习(二)—— PostgreSQL数据库的备份转储和导入恢复
数据库
无名之逆4 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
s9123601014 小时前
rust 同时处理多个异步任务
java·数据库·rust
数据智能老司机4 小时前
CockroachDB权威指南——CockroachDB 架构
数据库·分布式·架构
hzulwy4 小时前
Redis常用的数据结构及其使用场景
数据库·redis
程序猿熊跃晖4 小时前
解决 MyBatis-Plus 中 `update.setProcInsId(null)` 不生效的问题
数据库·tomcat·mybatis
FAREWELL000755 小时前
C#核心学习(七)面向对象--封装(6)C#中的拓展方法与运算符重载: 让代码更“聪明”的魔法
学习·c#·面向对象·运算符重载·oop·拓展方法