我使用EF5.0 Code First Migrations成功地运行了默认的ASP.NET MVC4模板。但是,当我更新模型属性名称时,EF 5.0丢弃了相应的表列数据。
有没有可能在不以自动方式删除数据的情况下重命名表列?
发布于 2012-11-29 08:41:26
手动编辑迁移的Up和Down方法,使用RenameColumn
方法替换它自动为您生成的AddColumn
和DropColumn
。
发布于 2015-12-24 07:03:52
As already said,将自动生成的AddColumn
和DropColumn
替换为RenameColumn
。
示例:
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");
}
}
}
发布于 2012-10-28 06:33:08
现在,这个答案是基于我对EF4.3的了解,所以我希望迁移在EF5中的工作大致相同:)在创建迁移之后,您应该能够在删除旧属性和创建新属性之间的Up和Down方法中添加代码。此代码应将属性数据移动到正确的方向。我已经用SQL()方法解决了这个问题,您可以在其中输入原始SQL来执行数据移动。
在迁移的Up方法中:
SQL("update [TheTable] set [NewColumn] = [OldColumn]");
在Down()方法中:
SQL("update [TheTable] set [OldColumn] = [NewColumn]");
这种方法的缺点是,您可能会将代码与当前正在使用的数据库耦合在一起(因为您正在编写原始的特定于DB的SQL)。可能还有其他方法可用于数据移动。
欲了解更多信息,请访问:MSDN
https://stackoverflow.com/questions/13104592
复制相似问题