.Net Core - 根据环境更改数据库迁移

.Net Core - Change database migrations depending on environment

因此,我试图找出针对开发中的 PostgreSQL 数据库和生产中的 SQL 服务器数据库的 运行 应用程序的黄金路径。困难的部分是迁移会有所不同。目前,我的做法是这样的:

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 进行多个定义吗?

经过一段时间的思考,我认为这是一个反模式。不管我的具体用例是什么(开发中的 postgres,生产中的 SQL 服务器),我认为对不同的环境使用不同的数据库系统是不受欢迎的,因为部署后可能会出现意想不到的问题。开发和生产最好坚持使用同一个。