首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在Entity Framework5 Code First迁移中重命名数据库列而不丢失数据?

如何在Entity Framework5 Code First迁移中重命名数据库列而不丢失数据?
EN

Stack Overflow用户
提问于 2012-10-28 06:05:58
回答 5查看 42.3K关注 0票数 76

我使用EF5.0 Code First Migrations成功地运行了默认的ASP.NET MVC4模板。但是,当我更新模型属性名称时,EF 5.0丢弃了相应的表列数据。

有没有可能在不以自动方式删除数据的情况下重命名表列?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2012-11-29 08:41:26

手动编辑迁移的Up和Down方法,使用RenameColumn方法替换它自动为您生成的AddColumnDropColumn

票数 117
EN

Stack Overflow用户

发布于 2015-12-24 07:03:52

As already said,将自动生成的AddColumnDropColumn替换为RenameColumn

示例:

代码语言:javascript
复制
namespace MyProject.Model.Migrations
{
    using System;
    using System.Data.Entity.Migrations;

    public partial class RenameMyColumn : DbMigration
    {
        public override void Up()
        {
            // Remove the following auto-generated lines
            AddColumn("dbo.MyTable", "NewColumn", c => c.String(nullable: false, maxLength: 50));
            DropColumn("dbo.MyTable", "OldColumn");

            // Add this line
            RenameColumn("dbo.MyTable", "OldColumn", "NewColumn");
        }

        public override void Down()
        {
            // Remove the following auto-generated lines
            AddColumn("dbo.MyTable", "OldColumn", c => c.String(nullable: false, maxLength: 50));
            DropColumn("dbo.MyTable", "NewColumn");

            // Add this line
            RenameColumn("dbo.MyTable", "NewColumn", "OldColumn");
        }
    }
}
票数 47
EN

Stack Overflow用户

发布于 2012-10-28 06:33:08

现在,这个答案是基于我对EF4.3的了解,所以我希望迁移在EF5中的工作大致相同:)在创建迁移之后,您应该能够在删除旧属性和创建新属性之间的Up和Down方法中添加代码。此代码应将属性数据移动到正确的方向。我已经用SQL()方法解决了这个问题,您可以在其中输入原始SQL来执行数据移动。

在迁移的Up方法中:

代码语言:javascript
复制
SQL("update [TheTable] set [NewColumn] = [OldColumn]");

在Down()方法中:

代码语言:javascript
复制
SQL("update [TheTable] set [OldColumn] = [NewColumn]");

这种方法的缺点是,您可能会将代码与当前正在使用的数据库耦合在一起(因为您正在编写原始的特定于DB的SQL)。可能还有其他方法可用于数据移动。

欲了解更多信息,请访问:MSDN

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13104592

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档