C# 实体框架4.1代码第一外键Id';s

C# 实体框架4.1代码第一外键Id';s,c#,poco,entity-framework-4.1,C#,Poco,Entity Framework 4.1,我有两个实体,一对多引用。实体框架创建表时,会创建两个外键,一个用于我用fluent接口指定的键,另一个用于ICollection。如何删除重复的外键 public class Person { public long RecordId { get; set; } public string FirstName { get; set; } public string LastName { get; set; } public string Email { get;

我有两个实体,一对多引用。实体框架创建表时,会创建两个外键,一个用于我用fluent接口指定的键,另一个用于ICollection。如何删除重复的外键

public class Person
{
    public long RecordId { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string Email { get; set; }
    public string Username { get; set; }

    public long DepartmentId { get; set; }
    public virtual Department Department { get; set; }
}

public class Department
{
    public long RecordId { get; set; }
    public string Name { get; set; }

    public virtual ICollection<Person> People { get; set; }
}

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<Person>()
        .HasRequired(p => p.Department)
        .WithMany()
        .HasForeignKey(p => p.DepartmentId)
        .WillCascadeOnDelete(false);
}
公共类人物
{
公共长记录ID{get;set;}
公共字符串名{get;set;}
公共字符串LastName{get;set;}
公共字符串电子邮件{get;set;}
公共字符串用户名{get;set;}
公共长部门ID{get;set;}
公共虚拟部门部门{get;set;}
}
公共课系
{
公共长记录ID{get;set;}
公共字符串名称{get;set;}
公共虚拟ICollection人员{get;set;}
}
模型创建时受保护的覆盖无效(DbModelBuilder modelBuilder)
{
modelBuilder.Entity()
.has必需(p=>p.Department)
.有很多
.HasForeignKey(p=>p.DepartmentId)
.WillCascadeOnDelete(假);
}

谢谢

默认的代码优先约定检测您的部门ID外键,因为它是传统的。我认为你应该删除Fluent的定义:

modelBuilder.Entity<Person>()
    .HasRequired(p => p.Department)
    .WithMany()
    .WillCascadeOnDelete(false);
modelBuilder.Entity()
.has必需(p=>p.Department)
.有很多
.WillCascadeOnDelete(假);

必须明确指定关联的多个端点:

modelBuilder.Entity<Person>()
    .HasRequired(p => p.Department)
    .WithMany(d => d.People)
    .HasForeignKey(p => p.DepartmentId)
    .WillCascadeOnDelete(false);
modelBuilder.Entity()
.has必需(p=>p.Department)
.有很多人(d=>d.人)
.HasForeignKey(p=>p.DepartmentId)
.WillCascadeOnDelete(假);

否则,EF将假定存在两个关联:一个关联未在
部门中公开,外键
部门ID
和导航属性
部门
位于
人员
类中,如您在流畅代码中定义的,另一个关联属于公开的导航属性
People
,但在
Person
中有另一个未暴露的端,并且EF自动创建一个外键。这是您在数据库中看到的另一个键。

最好的方法是从Person类中删除departmentid属性,并添加以下语句。MapKey将使用指定的名称创建外键列

 modelBuilder.Entity<Person>().HasRequired(p =>  p.Department)
    .WithMany().Map(x=>x.MapKey("DepartmentId"))
    .WillCascadeOnDelete(false);
modelBuilder.Entity().HasRequired(p=>p.Department)
.WithMany().Map(x=>x.MapKey(“部门ID”))
.WillCascadeOnDelete(假);

这行得通吗??:[ForeignKey(“Department”)]public long DepartmentId{get;set;}@billy:它不是100%相同,因为注释没有禁用级联删除。如果您不想禁用级联删除,那么它可以工作,是的。但是您甚至不需要注释,因为命名约定将自动检测外键属性。我尝试了这种方法,但在运行
Seed()
方法时,它导致了异常,该方法引用默认列名,而不是
MapKey()
中指定的列名。