EFコア複数のマイグレーションセット

.net-core entity-framework-core

質問

私は現在、EF Core Code First Migrationsを使って.Net Coreアプリを開発中です。私はWindowsとOS Xの間で開発を進めています(自宅のWindows、Mac)。私はWindowsとSQLite上でSQL Serverのデータベース移行をどのように使うことができるかを把握しようとしています。マック。

2組の移行を維持し、適用するセットを選択することは可能ですか(各移行を個別に指定する必要はありません)。または、別の.Netコアアプリケーション/アセンブリを作成し、 --assembly dotnet ef database updateコマンドの--assemblyオプションを指定する必要がありますか?

受け入れられた回答

あなたには2つの選択肢があります:

  1. 2組の移行を使用する
  2. プロバイダに依存しないように手動で移行を編集する

複数のセット

各セットは、それ自身のアセンブリ内にある必要があります。開始するには、最初の移行を生成し、それを新しいプロジェクトに移動します。プロバイダの構成時に移行アセンブリを構成します。

optionsBuilder.UseSqlServer(
    mssqlConnectionString
    , x => x.MigrationsAssembly("MyApp.Migrations.SqlServer"));
//optionsBuilder.UseSqlite(
//    sqliteConnectionString,
//    x => x.MigrationsAssembly("MyApp.Migrations.Sqlite"));

私は自分のアセンブリにマイグレーションを置くサンプルを用意しておきます。

プロバイダに依存しない

移行をプロバイダに依存しないようにするには、各プロバイダが生成するものをマージします。たとえば、SQL ServerとSQLiteの両方のアノテーションがあります。

migrationBuilder.CreateTable(
    name: "People",
    columns: table => new
    {
        Id = table.Column<int>(nullable: false)
            .Annotation("Sqlite:Autoincrement", true)
            .Annotation("SqlServer:ValueGenerationStrategy",
                SqlServerValueGenerationStrategy.IdentityColumn)
    },
    constraints: table =>
    {
        table.PrimaryKey("PK_People", x => x.Id);
    });


Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ