用了codefirst后一个很大的问题就是代码中的属性字段与数据库中表的同步问题,删掉数据库重新生成当然可以解决,不过数据就丢失了(当然通过代码中初始化数据库添加数据也可以解决,初始化的任务可以通过重写Seed方法实现)。很多情况我们希望测试数据还在,通过查询知道Code First Migrations这个方案。
网上已经有很多关于Code First Migrations 的操作步骤类文章,这里只记录我遇到的一些问题
ps:开发环境 vs2013 rtm+SQLServer 2008+EF4.4
1.PM> update-database时报错: Could not load file Microsoft.VisualStudio.Shell 10
解决步骤:
a.安装Microsoft.VisualStudio.Shell 10,问题依旧
b.msdn论坛上微软官方的解决方案是安装vs2013 update2,我安装了update4,问题依旧。
c.*上建议安装Microsoft.VisualStudio.Shell 12,安装后解决!这个解决方式让人摸不着头脑,报的错误是shell10的错误,竟然安装shell12可以解决。
链接:https://www.microsoft.com/en-us/download/details.aspx?id=30670
2.PM> Enable-Migrations -Force,force参数是强行修改的意思,不加此参数会收到丢失数据的警告
3.在生成的Confifuration.cs文件中设置 AutomaticMigrationsEnabled = true; --数据库架构同步
4.PM> add-migration AddCardDataAddTimeMig,AddCardDataAddTimeMig是生成类的名字,由自己定义。我这里是要在Consumes表中加一个CardDataAddTime字段,类型为字符串
然后修改代码:
public override void Up() { AddColumn("dbo.Consumes", "CardDataAddTime", c => c.String()); } public override void Down() { DropColumn("dbo.Consumes", "CardDataAddTime"); }
ps:如果你新增了表, 会自动生成CreateTable代码段
5.PM> update-database 如果没有报错的话,这里执行完数据库就已经更新了。