Я пытаюсь переименовать имена таблиц по умолчанию, созданные ASP.net Identity 2.0. Я прочитал все статьи, вопросы и ответы на stackoverflow, но я все равно получаю ту же ошибку.
Я переименовал эти таблицы в роли, UserClaims, Logins, UserRoles и Users. Я также изменил приложение dbcontext на следующие
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
public ApplicationDbContext()
: base("DefaultConnection", throwIfV1Schema: false)
{
}
public static ApplicationDbContext Create()
{
return new ApplicationDbContext();
}
protected override void OnModelCreating(System.Data.Entity.DbModelBuilder modelBuilder) {
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<IdentityUser>().ToTable("Users", "dbo");
modelBuilder.Entity<IdentityRole>().ToTable("Roles", "dbo");
modelBuilder.Entity<IdentityUserRole>().ToTable("UserRoles", "dbo");
modelBuilder.Entity<IdentityUserClaim>().ToTable("UserClaims", "dbo");
modelBuilder.Entity<IdentityUserLogin>().ToTable("UserLogins", "dbo");
}
}
Но я продолжаю получать ошибку Invalid object name 'dbo.AspNetUsers'.
, и я понятия не имею, почему она все еще пытается найти AspNetUsers в первую очередь, а не просто пользователей, хотя я сделал изменения выше. В настоящее время полностью отчаянно.
В базе данных также одинаковые столбцы с именами новых таблиц:
И проект базы данных SQL: