.Net Core - 環境に応じてデータベースの移行を変更する

.net-core c# entity-framework-core

質問

だから私は、開発のPostgreSQLデータベースと本番環境のSQL Serverデータベースに対してアプリケーションを実行するためのゴールデンパスが何であるかを把握しようとしています。難しいのは、移行が異なることです。現在、私のアプローチは次のようなものです:

public void ConfigureServices(IServiceCollection services)
{
  services.AddDbContext<ApplicationDbContext>(SetDbContextOptionsForEnvironment, ServiceLifetime.Transient);
}

private void SetDbContextOptionsForEnvironment(DbContextOptionsBuilder options)
{
  if(_environmentName == "production") {
    options.UseSqlServer(Configuration["Data:DefaultConnection:ConnectionString"]);
  }
  else {
    options.UseNpgsql(Configuration["Data:DefaultConnection:ConnectionString"]);
  }
}

別のアセンブリに移行を保ち、そのアセンブリをオプションで指定することをお勧めしますか?だから、私はそれらのアセンブリでも同じDbContextの複数の定義を持つ必要がありますか?

受け入れられた回答

このことをかなり考えてから、私はこれが反パターンであると信じています。私の特定のユースケース(devのpostgres、prodのSQL Server)に関係なく、展開後に予期しない問題が発生する可能性があるため、さまざまな環境で異なるデータベースシステムを使用することは嫌われると思います。開発と生産のために同じものをつけるのがベストです。



Related

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