我试图在我的AspNetUser(ApplicationUser类)表和Employee表之间创建一对一的关系。

问题是:

  • 我的应用程序与Employee表之间的关系如此之多,因此我无法创建组合键。

  • 我试过的
  • 我尝试使用唯一索引,但是实体框架不支持索引。
  • 我试图将外键放在ApplicationUser类中,但是我想asp.net身份不支持AspNetUsers表中的复合键。

  • 这是我希望实现的示例:
    public class ApplicationUser : IdentityUser<int, CustomUserLogin, CustomUserRole, CustomUserClaim>
        {
            public ApplicationUser()
                : base()
            {
                PreviousUserPasswords = new List<PreviousPassword>();
            }
            public virtual IList<PreviousPassword> PreviousUserPasswords { get; set; }
    
            public virtual Employee Employee { get; set; }
        }
    
        [Table("EMPLOYEE")]
        public class Employee
        {
            [Key, Column("ID")]
            public int Id { get; set; }
            [Column("ID_IDIOM")]
            public int IdIdiom { get; set; }
            [Column("USER_LOGIN")]
            [Required]
            [StringLength(50)]
            public string UserName { get; set; }
            [Column("NAME")]
            [Required]
            [StringLength(100)]
            public string Name { get; set; }
            [Column("EMAIL")]
            [Required]
            [StringLength(100)]
            public string Email { get; set; }
            [Column("ACTIVE")]
            public bool Active { get; set; }
            [Column("EMPLOYEE_TYPE")]
            public short EmployeeType { get; set; }
            [Column("SHOW_TUTORIAL")]
            public bool ShowTutorial { get; set; }
    
            public ApplicationUser User { get; set; }
        }
    

    任何想法都会有很大帮助。

    PS:对不起,我的英语不好。

    最佳答案

    如果您的应用程序上下文是从IdentityDbContext继承的,则可以使用流利的api进行配置:

    modelBuilder.Entity<Employee>()
       .HasRequired(e => e.User)
       .WithRequiredDependent(u => u.Employee);
    

    参见https://msdn.microsoft.com/en-us/data/jj591620.aspx?f=255&MSPPError=-2147217396#RequiredToRequired

    关于entity-framework-6 - 如何在身份用户和我的Employee表之间创建一对一关系,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/32784426/

    10-11 09:14
    查看更多