6

我来自 asp.net Web Forms 切换到 MVC 和实体框架代码优先方法。我有个问题。如何设置我的环境以部署到生产环境?

我正在使用 Visual Studio 2012 并部署一个 Web 部署包。在本地,我有 SQL Express,在生产中,我有 SQL Server 2008。

我想要的是在我的电脑上本地开发一个测试,并不时使用 web 部署包将我的解决方案部署到生产中。我不想在生产系统中运行迁移,而是想从 Visual Studio 生成脚本,然后我可以将其附加到生产 SQL。

我尝试过了:

  • 在 dev 中创建初始迁移。
  • 本地更新数据库
  • 生成脚本,update-database -script -sourcemigration:InitialCreate
  • 在生产中应用此脚本
  • 将应用程序部署到生产环境

这是正确的方法吗?我的迁移将在本地运行,它们会不会因为我的迁移代码而在我部署时不在生产中?

在 global.asax

Migrator.RunMigrations();

其中 RunMigrations 是这样的自定义 Migrator 类中的静态方法

public class Migrator
    {
        public static void RunMigrations()
        {
            var migrator = new Configuration();
            var dbMigrator = new System.Data.Entity.Migrations.DbMigrator(migrator);
            if (dbMigrator.GetPendingMigrations().Any())
            {
                dbMigrator.Update();
            }
        }
    }
4

2 回答 2

2

您可以使用Web 安装项目(安装需要 MSI 自定义操作):

更新数据库的实际工作可以通过 migrate.exe 工具来完成。要使 MSI 程序包正确运行,结果证明是一个挑战。我首先在安装包中包含了 migrate.exe ,以便将它与系统的程序集一起部署到 bin 目录中。支持将.exe文件作为 Web 设置项目中的自定义操作运行。不幸的是,除非工作目录设置为 bin 目录,否则我无法让 migrate.exe 工作。默认情况下,自定义操作的工作目录是 c:\windows\system32。为了解决这个问题,使用了一个小的 vb 脚本。

http://coding.abel.nu/2012/04/update-database-msi-custom-action/

更新:

我找到了这个这个这个,也许它会有所帮助。

于 2013-07-04T07:35:25.683 回答
0

回滚所有迁移

更新数据库-TargetMigration:0

更新数据库脚本

https://cpratt.co/migrating-production-database-with-entity-framework-code-first/

于 2017-10-02T18:55:32.347 回答