加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 更新模型更改时的数据库模式,不会丢失数据

发布时间:2020-12-16 01:51:22 所属栏目:百科 来源:网络整理
导读:背景:假设我使用的是实体框架,其中一个映射的实体给出如下: class Foo{ public int ID { get; set; } public string Bar { get; set; } // other useful properties} 随着映射: class FooMap : EntityTypeConfigurationFoo{ // bear me with,I know this
背景:假设我使用的是实体框架,其中一个映射的实体给出如下:

class Foo
{
    public int ID { get; set; }
    public string Bar { get; set; }
    // other useful properties
}

随着映射:

class FooMap : EntityTypeConfiguration<Foo>
{
    // bear me with,I know this is redundant right now
    ToTable("Foo");
    HasKey(e => e.ID);
    Property(e => e.ID).HasColumnName("ID");
    Property(e => e.Bar);
}

在某个地方,我们需要更改Foo的列名,因为我的老板告诉我Foo需要一个比ID更奢侈的名字,否则我们的客户会不高兴.他告诉我们将它重命名为“FooID”:

class FooMap : EntityTypeConfiguration<Foo>
{
    // bear me with,I know this is redundant right now
    ToTable("Foo");
    HasKey(e => e.ID);
    Property(e => e.ID).HasColumnName("FooID"); // Now you map to FooID
    Property(e => e.Bar);
}

就目前而言,如果我这样做,一切都不会改变. Foo表仍然会有一个名为ID的列,它会抛出一个异常,告诉我FooID列不存在.

问题:如何让实体框架认识到我现在希望更新Foo表,以便名为ID的列现在命名为FooID?

更一般地说,如何让实体框架自动将我的代码中的更改传播到实际的数据库中(例如在应用程序启动时)而不破坏现有数据?

我不能只是“删除并重新创建”数据库,因为由于超出此问题范围的原因,数据库会在其中存储一些其他数据,这些数据不是通过我的代码中映射的模型创建的.删除它会导致我们丢失我们不能使用此机制重新创建的表.

解决方法

我相信以下两篇文章会对你有帮助.

> Using EF 4.3 Code First Migrations with an Existing Database
> EF 4.3 Migration Walkthrough

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读