当前位置: 首页 > news >正文

第4章 4.4 EF Core数据库迁移 Add-Migration UpDate-Database

4.4.1 数据库迁移原理

 

总结一下就是:

1. 数据库迁移命令的执行,其实就是生成在数据库执行的脚本代码(两个文件:数字_迁移名.cs     数字_迁移名.Designer.cs),用于对数据库进行定义和修饰。

2. 数据库迁移有两个方法 【向上】和【向下】,个人理解:其实向上就是更新,向下就是还原上一版本。

演示一下。假设先已完成环境搭建,且创建了一个新的表格T_Dogs,模式如下:

public class Dog
{
    public long ID { get; set; }

    public string Name { get; set; }
}

现在给这个数据库增加一列,【Age】

public class Dog
{
    public long ID { get; set; }

    public string Name { get; set; }

    public int Age { get; set; }
}

然后 Add-Migration AddColumnAge

执行成功后观察项目目录,已经生成了对应的脚本文件:

然后检查这个脚本文件会发现,文件里有两个方法:Up:执行新增这一列的操作 Down:执行删除这一列的操作 ,代码如下:

public partial class AddColumnAge : Migration
{
    /// <inheritdoc />
    protected override void Up(MigrationBuilder migrationBuilder)
    {
        migrationBuilder.AddColumn<int>(
            name: "Age",
            table: "T_Dogs",
            type: "int",
            nullable: false,
            defaultValue: 0);
    }

    /// <inheritdoc />
    protected override void Down(MigrationBuilder migrationBuilder)
    {
        migrationBuilder.DropColumn(
            name: "Age",
            table: "T_Dogs");
    }
}

然后更新数据库:update-database

更新完成后查看数据库已完成新增这一列:

然后查看数据库的脚步执行历史,最后执行的就是刚才迁移时生成的脚本(20250223071051_AddColumnAge):

4.4.2 其他数据库迁移命令

当然,数据库迁移不光只有update-database和Add-Migration,EF Core还提供了一些其他的命令。下面介绍几个常用的:

1. update-database其他参数

update-database 【这里写迁移命令时的名称,可以将数据库回滚或者升级到对应的版本】

2. 删除迁移脚本Remove-migration

Remove-migration命令,删除最后一次的迁移脚本

3. 生成迁移脚本Script-Migration

在开发环境中可以随意使用update-database进行数据库更改迁移,但如果要修改实际生成环境的数据库的话需要相关人员审计才能被允许修改。

对于这种场景, EF Core中提供了Script-Migration命令来根据迁移代码生成SQL脚本,这个脚本可以通过审计后在生产数据库中执行。

此外,如果数据库已经是迁移版本的状态了,比如已经是D版本,要升级到F版本,则可以Script-Migration D F 来生成D到F的升级的脚本

4.4.3 反向工程(慎用)

杨老师说:这是一个灾难及操作,别用它。哈哈哈,其实也还好,就是确实不太推荐,应为这种方式不符合“模型驱动的开发理念”。

意思就是手动维护数据库,然后用反向工程生成实体类。

生成时用指令:

Scafflod-DBContext ‘Server=.;Database=demo1;Trusted_Connection=True;’ Microsoft.EntityFrameworkCore.SqlServer

相关文章:

  • Vue.js组件开发:从基础到进阶
  • 【LeetCode18】四数之和
  • 【论文学习】基于规模化Transformer模型的低比特率高质量语音编码
  • python与C系列语言的差异总结(1)
  • 玩机日记 10 fnOS 开启文件传输服务挂载到手机/电脑,测试传输性能
  • 设置 C++ 开发环境
  • 无数字字母rce总结(取反、异或、自增)
  • 计算机视觉算法实战——产品分拣(主页有源码)
  • 1.适配器模式
  • Deepseek AI模型 快速入门(详细版)
  • YOLO11的单独推理程序
  • POST请求提交数据的三种方式及通过Postman实现
  • Python Matplotlib图形美化指南
  • 蓝桥杯备赛-精卫填海-DP
  • 2024年第十五届蓝桥杯青少 图形化编程(Scratch)省赛中级组真题——截取递增数
  • 自由学习记录(38)
  • Lecture 1 - AI Systems (Overview)
  • AI前端开发对就业机会的双面影响:机遇与挑战并存
  • YaRN论文解读
  • 哈希表_快乐数
  • 女生“生理期请病假要脱裤子证明”?高校回应:视频经处理后有失真等问题
  • 中方是否计划解除或调整稀土出口管制?外交部回应
  • 国税总局上海市税务局回应刘晓庆被举报涉嫌偷漏税:正依法依规办理
  • 通用汽车回应进口车业务调整传闻:因经济形势变化重组,致力于在中国持续发展
  • 中欧金融工作组第二次会议在比利时布鲁塞尔举行
  • 国新办将就2025年4月份国民经济运行情况举行新闻发布会