gpt4 book ai didi

Nhibernate - 映射列表不更新列表索引

转载 作者:行者123 更新时间:2023-12-04 15:16:34 24 4
gpt4 key购买 nike

我有一个自引用类。一个 child 有一个对它的 parent 的引用,一个 parent 有一个 child 的列表。由于子列表是有序的,我试图使用 NHibernate 的 .

这是我的映射:

<class name="MyClass">
<id name="Id">
<generator class="native"/>
</id>
<list name="Children" cascade="delete" inverse="true">
<key column="ParentId"/>
<index column="ListOrder"/>
<one-to-many class="MyClass"/>
</list>
<many-to-one name="Parent" class="MyClass" column="ParentId"/>
</class>

我遇到的问题是当我有一个双向映射 child<->parent 时,当我进行 CRUD 舞蹈时,数据库中的列表索引 (ListOrder) 没有更新。这意味着当我例如删除一个 child ,在保存到数据库并再次获取父级后,我在 child 列表中出现了漏洞。如果我删除双向性,通过没有从子级到父级的多对一(并且没有 inverse=true),则 ListOrder 会正确更新。

你们有没有人见过这个?有什么简单的解决办法吗?

最佳答案

是的,这是因为 inverse=true,另一种解决方案是使用 set 或 bag 而不是带有 order="ListOrder"的列表,将 ListOrder 列作为属性添加到 MyClass 类,并使用空的 setter 和 getter从它的父子集合中返回它的索引。像这样:

<class name="MyClass">
<id name="Id">
<generator class="native"/>
</id>
<bag name="Children" cascade="delete" inverse="true" order-by="ListOrder">
<key column="ParentId"/>
<one-to-many class="MyClass"/>
</bag>
<property name="ListOrder" column="ListOrder"/>
<many-to-one name="Parent" class="MyClass" column="ParentId"/>
</class>

和类(class)
public class MyClass
{
public virtual int ID { get; set; }
public virtual IList<MyClass> Children { get; set; }
public virtual MyClass Parent { get; set; }

public virtual int ListOrder
{
get
{
if (Parent == null || !Parent.Children.Contains(this)) return -1;
return Parent.Children.IndexOf(this);
}
set { }
}
}

关于Nhibernate - 映射列表不更新列表索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1320966/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com