我想在不同的环境中执行迁移。我正在使用 Entity Framework 和 ASP.NET Core。现在我有这个:
public class TemporaryDbContextFactory : IDbContextFactory<ApplicationDbContext>
{
public ApplicationDbContext Create(DbContextFactoryOptions options)
{
var builder = new DbContextOptionsBuilder<ApplicationDbContext>();
builder.UseSqlServer("Data Source=.\\LOCALHOST;Initial Catalog=MyDB;Integrated Security=True;MultipleActiveResultSets=true");
return new ApplicationDbContext(builder.Options);
}
}
此代码位于 DAL 类库中,它将数据库交互与服务器代码分开。
执行迁移时使用它是可以的,但我不太喜欢这样做。
这里的问题是我使用本地数据库进行开发,但我们还有一个开发服务器和一个具有不同连接字符串的临时服务器。我无法做到的是找到一种不在该类中硬编码连接字符串的方法。
有没有办法为不同环境配置连接字符串并指示执行迁移时使用哪个连接字符串?
最佳答案
是的,您可以为此使用环境变量。
这就是为什么你有 appsettings.<EnvironmentName>.json
Configuration in ASP.NET Core
不错的微软文章关于Working with multiple environments
关于c# - 在类库中执行asp.net core EF迁移,无需硬编码连接字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43043235/