Entity Framework Code First 修改数据结构

相信刚接触EF Code First 的时候 都会被他的强大而震撼。

然而随着开发的深入,肯定会有修改之前结构的情况,例如添加或删除一个自动,修改一个字段属性。

EF本身也提供了一些功能:

Database.SetInitializer<XXContext>(
    new DropCreateDatabaseIfModelChanges<XXContext>());

但是如果在生产环境这种方式肯定是不可取的。

最灵活的方式,也是最原始的方式就是放弃EF自动同步的功能,自己修改实体类,自己修改数据库结构。

操作方法如下:

要先删除数据库中dbo.EdmMetadata这张表,或者修改表名也是可以的。
比如我现在往Category类中加一个Status字段
public string Status { get; set; }

然后往数据库的Categories表中也添加Stauts这个字段,这样程序还是能照常运行的,不会清空数据库原有内容。


不过这样以后,code first的功能就无法使用了,如果你建立新的model,它不再自动帮你创建表了。

当然一个系统已经进入了生产环境,数据结构不可能变动太大,放弃EF的自动同步功能也是值得的。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值