流畅的非hibernate循环依赖

本文关键字:循环 依赖 hibernate | 更新日期: 2023-09-27 17:52:35

我有2个实体,一切都很好,除了NHibernate不会在对象的第二个实体中加载FieldGroupItems属性。我怀疑这是因为这两个实体之间存在循环依赖关系。我真的需要两个ChildGroups和FieldGroupItems。如果我删除ChildGroups比FieldGroupItems加载很好。有没有办法得到我想要的。我能想到的唯一方法是使用Guid集合而不是对象集合来存储id并手动从代码中获取数据。如有任何帮助,不胜感激。

public class FieldGroupItemInstance : TenantBaseEntity
{
    public virtual Guid ItemId { get; set; }  //ID from the database to update actual object later
    public virtual bool IsTemporaryId { get; set; }  //true if field group is new (doesn't exist in system)
    public virtual IList<QuestionnaireInstanceField> Fields { get; set; }
    public virtual IList<QuestionnaireFieldGroupInstance> ChildGroups { get; set; }
    public FieldGroupItemInstance()
    {
        Fields = new List<QuestionnaireInstanceField>();
        ChildGroups = new List<QuestionnaireFieldGroupInstance>();
    }
}
public class QuestionnaireFieldGroupInstance : TenantBaseEntity
{
    public virtual Guid FieldGroupTemplateId { get; set; }
    public virtual IList<FieldGroupItemInstance> FieldGroupItems { get; set; } //Each repeated group of instances
    //public virtual FieldGroupItemInstance Parent { get; set; }
    public QuestionnaireFieldGroupInstance()
    {
        FieldGroupItems = new List<FieldGroupItemInstance>();
    }
}

流畅的非hibernate循环依赖

如果您正在使用fluenthibernate来映射您的实体,这应该可以工作。只要注意Cascade选项。

public class FieldGroupItemInstanceMap() 
{
        public FieldGroupItemInstanceMap()
        {
                Table("FieldGroupItemInstance");
                HasManyToMany(x => x.ChildGroups)
                        .Table("FieldGroupItemInstance_QuestionnaireFieldGroupInstance")
                        .ParentKeyColumn("IdFieldGroupItemInstance")
                        .ChildKeyColumn("IdQuestionnaireFieldGroupInstance")
                        .Cascade.None();
        }
}
public class QuestionnaireFieldGroupInstanceMap() 
{
        public QuestionnaireFieldGroupInstanceMap()
        {
                Table("QuestionnaireFieldGroupInstance");
                HasManyToMany(x => x.FieldGroupItems)
                        .Table("FieldGroupItemInstance_QuestionnaireFieldGroupInstance")
                        .ParentKeyColumn("IdQuestionnaireFieldGroupInstance")
                        .ChildKeyColumn("IdFieldGroupItemInstance")
                        .Cascade.None();
        }
}