1

我有一个class叫做 Section

public class Section
{
    public Section() { construct(0); }
    public Section(int order) { construct(order); }
    private void construct(int order) 
    {
        Children = new List<Section>();
        Fields = new List<XfaField>();
        Hint = new Hint();
        Order = order;
    }

    [Key]
    public int Id { get; set; }

    public int FormId { get; set; }

    public string Name { get; set; }

    [InverseProperty("Parent")]
    public List<Section> Children { get; set; }

    public List<XfaField> Fields { get; set; }

    public Section Parent { get; set; }

    public Hint Hint { get; set; }

    public int Order { get; private set; }


    #region Methods
    public void AddNewChild()
    {
        AddChild(new Section
        {
            Name = "New Child Section",
            FormId = FormId,
        });
    }
    private void AddChild(Section child)
    {
        child.Parent = this;

        if (Children == null) Children = new List<Section>();

        int maxOrder = -1;
        if(Children.Count() > 0) maxOrder = Children.Max(x => x.Order);

        child.Order = ++maxOrder;

        Children.Add(child);

        FactoryTools.Factory.PdfSections.Add(child);
    }
    // Other methods here
    #endregion
}

我正在尝试将一个新孩子添加Section到已经存在的父母中,如下所示:

    private void AddChildSection()
    {
        var parent = FactoryTools.Factory.PdfSections.FirstOrDefault(x => x.Id == ParentId);

        if (parent == null) throw new Exception("Unable to create child because parent with Id " + ParentId.ToString() + " doesn't exist.");

        parent.AddNewChild();

        FactoryTools.Factory.SaveChanges();
    }

当我查看数据库时,我看到添加了一个新行,例如:

Id  Name                Parent_Id   Hint_Id FormId  Order
19  New Child Section   1           27      1       0

但是,当我加载 parent 时Section,该Children属性始终为Count0,如下所示:

    public ActionResult EditSection(int formId, int sectionId)
    {
        var model = FactoryTools.Factory.PdfSections.FirstOrDefault(x => x.Id == sectionId);

        if (model == null || model.FormId != formId) model = new Section();

        //model.Children = FactoryTools.Factory.PdfSections.Where(x => x.Parent.Id == sectionId).ToList();

        return PartialView(model);
    }

当然,当我手动添加孩子时,他们就在那里(在上面的代码中,通过取消注释该model.Children = ...行)

我习惯了 NHibernate 的做事方式,因此对上述看似简单的任务在 EntityFramework 中不起作用感到非常沮丧,我做错了什么?

4

1 回答 1

2

实体框架不会急切地加载相关实体。尝试强迫它包括孩子:

var model = FactoryTools.Factory.PdfSections.Include("Children").FirstOrDefault(x => x.Id == sectionId);

还有一个强类型重载,您可以将 lambda 传递给它:

var model = FactoryTools.Factory.PdfSections.Include(s => s.Children).FirstOrDefault(x => x.Id == sectionId);
于 2013-03-11T04:47:56.077 回答