如何解决实体框架验证错误?

时间:2016-10-10 12:49:38

标签: c# asp.net-mvc entity-framework ef-code-first

我正在创建一个自定义表并使用Identity。我有一个向这个表添加行的上下文。

public class UserRoleAccess
{
    [Key]
    public string Id { get; set; }

    public string UserRoleId { get; set; }

    [ForeignKey("Id")]
    public virtual ApplicationRole ApplicationRole { get; set; }

    public bool IsActive { get; set; }

    public string Name { get; set; }

    public int UserRoleAccessType { get; set; }
}

db context:

public class UserRoleAccessContext : DbContext
{
    public UserRoleAccessContext() : base("DMConnection")
    {
        Database.SetInitializer<PersonContext>(null);
        Configuration.LazyLoadingEnabled = false;
        Configuration.ProxyCreationEnabled = false;
    }

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

    public DbSet<UserRoleAccess> UserRoleAccess { get; set; }

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

        //modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();

        // IMPORTANT: we are mapping the entity User to the same table as the entity ApplicationUser
        //modelBuilder.Entity<IdentityUserLogin>().ToTable("Users").HasKey(e => e.UserId);

    }

    public DbQuery<T> Query<T>() where T : class
    {
        return Set<T>();
    }
}

绑定

    protected override void OnModelCreating(System.Data.Entity.DbModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
        modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();


        modelBuilder.Entity<ApplicationUser>().HasRequired(p => p.Person)
            .WithMany(b => b.Users);

        modelBuilder.Entity<ApplicationUser>().HasRequired(p => p.Person)
            .WithMany(b => b.Users)
            .HasForeignKey(p => p.PersonId);

        modelBuilder.Entity<UserRoleAccess>().HasRequired(p => p.ApplicationRole)
                    .WithMany(b => b.UserRoleAccess);

        modelBuilder.Entity<UserRoleAccess>().HasRequired(p => p.ApplicationRole)
            .WithMany(b => b.UserRoleAccess)
            .HasForeignKey(p => p.UserRoleId);

    }

出现错误时执行此代码:

    public static void CreateUserRoleAccess(string name, int type, string id)
    {
        var userAccessContext = new UserRoleAccessContext();
        var userRoleAccess = new UserRoleAccess();

        userRoleAccess.UserRoleId = id;
        userRoleAccess.IsActive = true;

        userRoleAccess.UserRoleAccessType = type;

        userRoleAccess.Name = name;

        userAccessContext.UserRoleAccess.Add(userRoleAccess);
    }

错误

  

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

     

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

我认为我在某个地方错过了绑定,但我无法弄清楚在哪里?

编辑: 我更改了UserRoleAccess类。我将Id从字符串更改为long 我在TSQL中试过这个。

  INSERT INTO UserRoleAccess (UserRoleId,IsActive, Name, UserRoleAccessType) VALUES('e5b2e76a-a106-4076-b219-6987411995e7', 1, 'TEST', 1)

有效。虽然从我的应用程序运行它时仍然会出现相同的错误

编辑2 在我的绑定中添加了这个:

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

结果仍然相同

1 个答案:

答案 0 :(得分:0)

这很有意思。

我的第二次编辑实际上是正确的。但由于某种原因,当我首先使用代码迁移和更新数据库时,它不起作用。

我删除了所有表格并通过迁移再次创建它们并且它可以正常工作。

虽然编辑时我必须将这些代码放在两个db上下文中:

        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 });