EF Core修改Migration更新数据库表

场景

需要通过EF Migration修改数据库一张表的名称,字段,主键,索引

一般重命名表,生成的ef migration会删除旧表,创建一张新表,如果想不删除旧表,需要修改生成的migration

protected override void Up(MigrationBuilder migrationBuilder)
{
			migrationBuilder.RenameTable(
                name: "oldTableName",
                newName: "newTableName");

            migrationBuilder.DropPrimaryKey(
                name: "old_pk",
                table: "newTableName");

            migrationBuilder.AddPrimaryKey("new_pk", "newTableName", "columnName");

            migrationBuilder.RenameIndex(
                name: "old_indexName",
                newName: "new_indexName",
                table: "newTableName");
            
            migrationBuilder.RenameColumn("old_columnName", "newTableName", "new_columnName");

}

protected override void Down(MigrationBuilder migrationBuilder)
        {
            migrationBuilder.RenameTable(
                name: "newTableName",
                newName: "oldTableName");

            migrationBuilder.DropPrimaryKey(
                name: "new_pk",
                table: "oldTableName");

            migrationBuilder.AddPrimaryKey("old_pk", "oldTableName", "coumnName");
            
            migrationBuilder.RenameIndex(
                name: "new_indexName",
                newName: "old_indexName",
                table: "oldTableName");
                
			migrationBuilder.RenameColumn("new_columnName", "oldTableName", "old_columnName");

        }
使用EF Core创建数据库并生成多个,可按以下步骤操作: ### 1. 安装必要的NuGet包 需要安装一些必要的NuGet包,根据数据库类型选择对应的包,一般常用的如下: ```plaintext Microsoft.EntityframeworkCore.SqlServer (根据自己的数据库类型选择对应的nuget包) Microsoft.EntityframeworkCore.Tools Microsoft.VisualStudio.Web.CodeGeneration.Design ``` 这部分内容可参考引用[3]。 ### 2. 创建实体类 创建多个实体类,例如创建实体类`Steel`等,每个实体类对应数据库中的一张。以`Steel`实体类为例,代码可能如下: ```csharp public class Steel { public int Id { get; set; } public string Name { get; set; } // 可以添加更多属性 } ``` 可参考创建数据步骤中创建实体类的内容,来自引用[1]。 ### 3. 创建DBContext类 创建一个继承自`DbContext`的类,在该类中为每个实体类创建`DbSet`属性。示例代码如下: ```csharp using Microsoft.EntityFrameworkCore; public class YourDbContext : DbContext { public DbSet<Steel> Steels { get; set; } // 可以为其他实体类添加更多的DbSet属性 protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { // 配置数据库连接字符串 optionsBuilder.UseSqlServer("YourConnectionString"); // 根据数据库类型修改 } } ``` 同样参考引用[1]中创建DBContext类的步骤。 ### 4. 执行数据库迁移和更新命令 在包管理器控制台执行以下命令: - 执行`Add-Migration`数据库迁移命令,此命令会根据实体类和`DbContext`的定义生成迁移脚本。例如: ```plaintext Add-Migration InitialCreate ``` - 执行`Update-Database`更新数据库命令,该命令会将迁移脚本应用到数据库,创建数据库。 ```plaintext Update-Database ``` 完成上述步骤后,就会在数据库中生成实体类对应的数据,可参考引用[1]中的相关步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值