使用实体框架迁移(Beta1),在开发期间使用更新数据库命令是很好的。
但是,当应用程序在某个客户的服务器上运行时,我真的希望我的应用程序在启动时自动将其数据库模式更新为最新版本。
这个是可能的吗?文档稀缺。
发布于 2011-12-15 07:39:32
在RTM之前,他们没有提供这样做的方法,在这一点上,他们承诺提供一个命令行应用程序和一个msdeploy提供程序。来源:http://blogs.msdn.com/b/adonet/archive/2011/11/29/code-first-migrations-beta-1-released.aspx
当然,powershell命令并不满足于此,它存储在packages目录中并且是纯文本,它似乎只是加载了存储在同一目录中的一个名为EntityFramework.Migrations.Commands的程序集。
通过对该程序集进行跟踪,我得出了以下结论
public class MyContext : DbContext
{
static MyContext()
{
DbMigrationsConfiguration configuration = new DbMigrationsConfiguration() {
MigrationsAssembly = typeof(MyContext).Assembly,
ContextType = typeof(MyContext),
AutomaticMigrationsEnabled = true,
};
DbMigrator dbMigrator = new DbMigrator(configuration);
dbMigrator.Update(null);
}
}
更新:经过一些实验,我想出了更多的东西
这意味着代码被简化为
DbMigrator dbMigrator = new DbMigrator(new NAMESPACE.TO.MIGRATIONS.Configuration());
dbMigrator.Update(null);
发布于 2015-04-11 10:47:50
此问题的另一个选项是添加
Database.SetInitializer<MyContext>(new MigrateDatabaseToLatestVersion<MyContext, NAMESPACE.TO.MIGRATIONS.Configuration>());
行添加到您的Global.asax
Application_Start
方法。
https://stackoverflow.com/questions/8508280
复制