我正在启动一个 vNext 项目,但在启动它时遇到了一些问题。我在ApplicationDbContext
类中添加了一个表,它成功地在数据库中创建了表(在我的例子中是在 Azure 中)。但是,我似乎无法正确实例化 adbContext
以在我的控制器中使用。
根据我以前的 ASP.NET EF 项目的经验,我可以在不传递任何参数的情况下实例化 ApplicationDbContext 类,但是在 vNext 的情况下,它似乎需要一些东西(IServiceProvider
和IOptionsAccessor<DbContextOptions>
)。我尝试创建一个无参数构造函数,但由于不知道要使用什么连接字符串,应用程序中断。我的代码在下面——正如您在OnConfiguring(DbContextOptions options)
覆盖中看到的那样,我通过 强制连接字符串DbContextOptions
,但这显然并不理想,我觉得我只是不明白这两个IServiceProvider
和 IOptionsAccessor 参数需要来自哪里。
谢谢你的帮助!
namespace Project.Models
{
// Add profile data for application users by adding properties to the ApplicationUser class
public class ApplicationUser : IdentityUser
{
public string CompanyName { get; set; }
}
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
private static bool _created = false;
public DbSet<Business> Businesses { get; set; }
public ApplicationDbContext()
: base()
{
if (!_created)
{
Database.EnsureCreated();
_created = true;
}
}
protected override void OnConfiguring(DbContextOptions options)
{
var configuration = new Configuration();
configuration.AddJsonFile("config.json");
configuration.AddEnvironmentVariables();
options.UseSqlServer(configuration.Get("Data:DefaultConnection:ConnectionString"));
}
public ApplicationDbContext(IServiceProvider serviceProvider, IOptionsAccessor<DbContextOptions> optionsAccessor)
: base(serviceProvider, optionsAccessor.Options)
{
// Create the database and schema if it doesn't exist
// This is a temporary workaround to create database until Entity Framework database migrations
// are supported in ASP.NET vNext
if (!_created)
{
Database.EnsureCreated();
_created = true;
}
}
}
}