我有一个mysql数据库托管在azure上,我的计算机上有mvc应用程序。我想使用identity框架来跟踪我的用户。在我的数据库中生成了标识表,但它们都有错误的名称:
因为当我想在我的注册页面上添加一个新用户时,会出现以下错误:
表xx.aspnetusers不存在。
我知道这是因为我的表名错了。但是我不知道为什么表被添加为my\u aspnet\u users而不是aspnetusers。
我遵循这篇文章作为指导:https://www.codeproject.com/tips/788357/how-to-set-up-application-using-asp-net-identity-w
我还尝试编辑我的applicationdbcontext:
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
public ApplicationDbContext()
: base("WebShopDatabaseContext")
{
Database.SetInitializer(new MySqlInitializer());
}
public static ApplicationDbContext Create()
{
return new ApplicationDbContext();
}
protected override void OnModelCreating(System.Data.Entity.DbModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<IdentityUser>().ToTable("aspnetusers");
modelBuilder.Entity<ApplicationUser>().ToTable("aspnetusers");
modelBuilder.Entity<IdentityUserRole>().ToTable("aspnetuserroles");
modelBuilder.Entity<IdentityUserLogin>().ToTable("aspnetuserlogins");
modelBuilder.Entity<IdentityUserClaim>().ToTable("aspnetuserclaims");
modelBuilder.Entity<IdentityRole>().ToTable("aspnetroles");
}
}
1条答案
按热度按时间0ve6wy6x1#
我不想弄明白为什么你的表名是这样的,
但是你可以配置你的
DbContext
使用实际的,如下所示。对每个表执行相同的操作。