7

我一直在尝试为我的集合类型创建导航属性,我发现了一个人如何使用 OnModelCreating 完成它的示例我在我的 MVC 5 应用程序中试了一下,在尝试更新我的数据库时收到了这个错误:

在模型生成期间检测到一个或多个验证错误:

BlogEngine.Models.IdentityUserLogin: : EntityType 'IdentityUserLogin' 没有定义键。定义此 EntityType 的键。BlogEngine.Models.IdentityUserRole: : EntityType 'IdentityUserRole' 没有定义键。定义此 EntityType 的键。IdentityUserLogins:EntityType:EntitySet 'IdentityUserLogins' 基于没有定义键的类型'IdentityUserLogin'。IdentityUserRoles:EntityType:EntitySet 'IdentityUserRoles' 基于没有定义键的类型'IdentityUserRole'。

如何解决这些“未定义键”错误?

我做了一些搜索,找到了解决一个用户问题的解决方案,但他的需求与我的不同。对于我正在尝试做的事情,这些解决方案似乎非常复杂。

这是导致问题的代码:

public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
    {
        public ApplicationDbContext()
            : base("DefaultConnection", throwIfV1Schema: false)
        {

        }
        //public DbSet<Image> Images { get; set; }

        public static ApplicationDbContext Create()
        {
            return new ApplicationDbContext();
        }

        public DbSet<Post> Posts { get; set; }
        public DbSet<Image> Images { get; set; }
        public DbSet<Album> Albums { get; set; }
        public DbSet<Tag> Tags { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);

            modelBuilder.Entity<Post>().
                 HasOptional(e => e.Tags).
                 WithMany().
                 HasForeignKey(m => m.Tags_Id);

            modelBuilder.Entity<Tag>().
                 HasOptional(e => e.Posts).
                 WithMany().
                 HasForeignKey(m => m.Posts_Id);
        }

    }

这是我的具有多对多关系的模型:

Gist 上的 Post.cs 模型

Gist 上的 Tag.cs​​ 模型


更新以显示 IdentityUser:

public class ApplicationUser : IdentityUser
    {
        public async Task<ClaimsIdentity> GenerateUserIdentityAsync(UserManager<ApplicationUser> manager)
        {
            // Note the authenticationType must match the one defined in CookieAuthenticationOptions.AuthenticationType
            var userIdentity = await manager.CreateIdentityAsync(this, DefaultAuthenticationTypes.ApplicationCookie);
            // Add custom user claims here
            return userIdentity;
        }
    }
4

3 回答 3

15

您可能需要添加如下内容OnModelCreating

modelBuilder.Entity<IdentityUserLogin>().HasKey<string>(l => l.UserId);
modelBuilder.Entity<IdentityRole>().HasKey<string>(r => r.Id);
modelBuilder.Entity<IdentityUserRole>().HasKey(r => new { r.RoleId, r.UserId });

也可以看看:

于 2015-05-20T20:06:10.877 回答
10

我认为问题在于您base已从OnModelCreating. 尝试添加,如下所示

protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);

        //Your configuration goes here
    }
于 2017-10-25T08:15:13.783 回答
2

我知道这是一个迟到的回应,这可能只适用于从事教程或学校项目的人!

对我来说,只需删除数据库、.mdf 和迁移文件夹即可修复它。现在,我不知道您是否正在使用迁移,但这对我有用。

我是新手,但我注意到 Identity 对密钥非常挑剔。删除迁移有助于解决我在项目中遇到的每个(godforsaken)迁移问题。

于 2015-08-29T23:14:59.860 回答