Множественный dbcontext ASP.NET Core не может добавить миграцию

У меня есть 2 DbContexts:

services.AddDbContext<ConfigDbContext>(options => options.UseSqlServer(Configuration["Data:ConfigSQLServer:ConnectionString"].ToString(), t => t.MigrationsAssembly("App.Web")));

services.AddDbContext<AppDbContext>(options => options.UseSqlServer(Configuration["Data:AppSQLServer:ConnectionString"].ToString(), t => t.MigrationsAssembly("App.Web")));

когда я пытаюсь бежать

dotnet ef migrations add Initial -c AppDbContext

Я получил:

No DbContext named 'AppDbContext' was found

Если я бегу:

dotnet ef dbcontext list

результат:

FullNamespace.ConfigDbContext

Не удается найти второй DbContext AppDbContext

Конфигдбконтекст:

public class ConfigDbContext : DbContext
{
    public ConfigDbContext()
    {

    }

    public ConfigDbContext(DbContextOptions<ConfigDbContext> options) : base(options)
    {

    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
    }
}

AppDbContext:

public class AppDbContext : IdentityDbContext<ApplicationUser, ApplicationRole, Guid>
{
    public AppDbContext()
    {

    }

    public ConfigDbContext(DbContextOptions<AppDbContext> options) : base(options)
    {

    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
    }
}

person user2818430    schedule 12.10.2017    source источник


Ответы (2)


У меня аналогичные настройки, за исключением того, что мои DbContext и IdentityDbCotenxt живут в разных сборках, отличных от веб-проекта.

Конфигдбконтекст

// Remove the parameter-less constructor

public class ConfigDbContext : DbContext
{
    public ConfigDbContext(DbContextOptions<ConfigDbContext> options) : base(options)
    { }

    rotected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
    }
}

AppDbContext

// Remove the parameter-less constructor
// Rename the constructor to AppDbContext, instead of ConfigDbContext

public class AppDbContext : IdentityDbContext<ApplicationUser, ApplicationRole, Guid>
{
    public AppDbContext(DbContextOptions<AppDbContext> options) : base(options)
    { }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
    }
}

Также в моем IdentityDbContext, если вы измените первичный ключ на Guid, мне также придется переопределить AppUserClaim, AppUserRole, AppUserLogin, AppRoleClaim и AppUserToken.

Мой пример IdentityDbContext

public class AppIdentityDbContext : IdentityDbContext<AppUser, AppRole, Guid, AppUserClaim, AppUserRole,
    AppUserLogin, AppRoleClaim, AppUserToken>
{
    public AppIdentityDbContext(DbContextOptions<AppIdentityDbContext> options)
        : base(options)
    {
    }

    protected override void OnModelCreating(ModelBuilder builder)
    {
        base.OnModelCreating(builder);

        builder.Entity<AppUser>().ToTable("User");
        builder.Entity<AppRole>().ToTable("Role");
        builder.Entity<AppUserRole>().ToTable("UserRole");

        builder.Entity<AppUserClaim>().ToTable("UserClaim");
        builder.Entity<AppRoleClaim>().ToTable("RoleClaim");

        builder.Entity<AppUserLogin>().ToTable("UserLogin");
        builder.Entity<AppUserToken>().ToTable("UserToken");
    }
}

Я не думаю, что это проблема, но если мои предложения с самого начала не решат проблему, можно попробовать.

person David Liang    schedule 12.10.2017

AppDbContext должен быть:

public class AppDbContext : IdentityDbContext<ApplicationUser, ApplicationRole, Guid>
{
    public AppDbContext(DbContextOptions<AppDbContext> options) : base(options)
    {

    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
    }
}
person dawnone    schedule 13.10.2017