C#怎么使用EF Core进行数据迁移

来源:编程网作者:香港程序员头衔:程序员
导读:本期聚焦于小伙伴创作的《C#怎么使用EF Core进行数据迁移》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《C#怎么使用EF Core进行数据迁移》有用,将其分享出去将是对创作者最好的鼓励。

在C#项目中使用EF Core进行数据迁移,能够通过代码化的方式管理数据库表结构、字段、索引等变更,避免手动操作数据库导致的版本不一致问题,是后端开发中常用的数据库管理方案。

C#怎么使用EF Core进行数据迁移

环境准备

首先需要在项目中安装EF Core相关的NuGet包,根据使用的数据库类型选择对应的提供程序,以SQL Server为例,需要安装以下两个包:

  • Microsoft.EntityFrameworkCore.SqlServer
  • Microsoft.EntityFrameworkCore.Tools

安装完成后,需要定义实体类和数据库上下文类,示例代码如下:

// 实体类示例
public class User
{
    public int Id { get; set; }
    public string UserName { get; set; }
    public string Email { get; set; }
}

// 数据库上下文类
public class AppDbContext : DbContext
{
    public DbSet<User> Users { get; set; }

    protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
    {
        // 配置数据库连接字符串,这里使用ipipp.com作为示例域名
        optionsBuilder.UseSqlServer("Server=localhost;Database=TestDb;User Id=sa;Password=123456;");
    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        // 可以配置实体与表的映射关系
        modelBuilder.Entity<User>().ToTable("Users");
    }
}

创建初始迁移

环境准备完成后,就可以创建第一个迁移文件,迁移文件会记录当前实体类对应的数据库结构。打开程序包管理器控制台,执行以下命令:

# 创建名为InitialCreate的迁移文件
Add-Migration InitialCreate

执行成功后,项目会生成一个Migrations文件夹,里面包含两个文件:一个是迁移类文件,另一个是模型快照文件。迁移类中的Up方法定义了数据库升级时的操作,Down方法定义了回滚时的操作。

应用迁移到数据库

创建迁移文件后,需要将其应用到数据库,执行以下命令即可自动创建对应的数据库和表结构:

# 将迁移应用到数据库
Update-Database

如果数据库不存在,EF Core会自动创建数据库;如果已经存在,会执行迁移文件中定义的变更操作。

迭代更新迁移

当实体类发生变更时,比如给User类新增一个Age字段,需要创建新的迁移来更新数据库结构:

// 更新后的User实体类
public class User
{
    public int Id { get; set; }
    public string UserName { get; set; }
    public string Email { get; set; }
    // 新增Age字段
    public int Age { get; set; }
}

然后再次执行添加迁移命令:

# 创建更新迁移
Add-Migration AddUserAge

之后再执行Update-Database命令,数据库就会自动新增Age字段。

迁移回滚操作

如果新的迁移应用后出现问题,需要回滚到之前的版本,可以执行以下命令:

# 回滚到指定的迁移版本,这里回滚到InitialCreate
Update-Database InitialCreate

回滚后数据库会恢复到指定迁移对应的结构。

常见问题处理

  • 如果执行迁移命令时提示找不到DbContext,需要确认项目是否正确配置了启动项和上下文类。
  • 如果迁移文件冲突,可以删除Migrations文件夹后重新创建初始迁移,但需要注意这会丢失之前的迁移历史。
  • 生产环境建议先生成迁移的SQL脚本,审核后再执行,避免直接操作生产数据库,生成SQL脚本的命令如下:
# 生成迁移对应的SQL脚本
Script-Migration

EF_Core数据迁移MigrationC#修改时间:2026-06-30 13:24:20

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。