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
以上是内存溢出为你收集整理的c# – 更新模型更改时的数据库模式,不会丢失数据全部内容,希望文章能够帮你解决c# – 更新模型更改时的数据库模式,不会丢失数据所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)