0

在 EF5 中定义模型时遇到问题。我想将其ParentId作为数据库中的外键,但出现错误:

System.Data.Entity.Edm.EdmAssociationType::多重性与关系“Category_Parent”中角色“Category_Parent_Target”中的引用约束冲突。因为从属角色中的所有属性都不可为空,所以主体角色的多重性必须为“1”。

这是我的模型:

public class Category
{
    public Category()
    {
        this.Childs = new HashSet<Category>();
    }
    public int CategoryId { get; set; }
    public string Name { get; set; }
    public int ParentId { get; set; }
    public virtual Category Parent { get; set; }
    public virtual ICollection<Category> Childs { get; set; } 
}

modelBuilder.Entity<Category>()
            .HasOptional(c => c.Parent)
            .WithMany(c => c.Childs)
            .HasForeignKey(d => d.ParentId);
4

1 回答 1

1

如果 aCategory可能有也可能没有 a Parent,那么 theParentId可能有也可能没有值。

因此,使ParentId可空:

public int? ParentId { get; set; }
于 2013-01-07T15:27:57.470 回答