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