4

我正在使用 FluentMigrator 来管理我的数据库更改,我像这样执行我的迁移:

const string connectionString = @"Data Source=localhost, 1433;Initial Catalog=testdb;Integrated Security=SSPI;";
            Announcer announcer = new TextWriterAnnouncer(s => System.Diagnostics.Debug.WriteLine(s));
            announcer.ShowSql = true;

            Assembly assembly = Assembly.GetAssembly(typeof (MigrationMarker));
            IRunnerContext migrationContext = new RunnerContext(announcer);

            var options = new ProcessorOptions
                              {
                                  PreviewOnly = false, // set to true to see the SQL
                                  Timeout = 60
                              };

            var factory = new SqlServer2008ProcessorFactory();
            IMigrationProcessor processor = factory.Create(connectionString, announcer, options);
            var runner = new MigrationRunner(assembly, migrationContext, processor);

            runner.MigrateUp(true);

我不知道的是如何为特定配置文件执行迁移?

因此,鉴于我的迁移器具有这样的属性:

[Profile("DevMigration")]
public class DevMigration : FluentMigrator.Migration
{

我尝试了以下几种变体:

runner.ProfileLoader.FindProfilesIn(assembly, "DevMigrator");
runner.ApplyProfiles();

但我没有更进一步,有谁知道我如何使用跑步者执行配置文件迁移?

4

2 回答 2

4

在传递给迁移运行程序之前,尝试在迁移上下文中设置配置文件,如下所示:

IRunnerContext migrationContext = new RunnerContext(announcer);
migrationContext.Profile = "DevMigrator"

配置文件加载器方法FindProfilesIn仅返回带有配置文件的迁移。RunnerContext加载的构造函数ProfileLoader默认加载上下文中指定配置文件的迁移(我认为这默认为 null 因此没有配置文件迁移)。

您不需要手动调用该ApplyProfiles方法,因为这是在MigrateUp(bool)方法中调用的。

于 2013-06-14T01:10:51.747 回答
4

对于稍后阅读它并使用进程内迁移器的人,如此处的文档中所示。在这种情况下指定配置文件名称的方法是在 ServiceCollection 上添加另一个配置调用,如下所示:

            .Configure<RunnerOptions>(cfg =>
            {
                cfg.Profile = "DevMigration";
            })
于 2019-06-05T09:45:13.043 回答