gpt4 book ai didi

hibernate - 如何避免 "N+1 Select"并为具有多对一的 (N)Hibernate 用户类型指定获取策略?

转载 作者:行者123 更新时间:2023-12-03 17:56:48 25 4
gpt4 key购买 nike

我有一个具有多对一引用的复合组件。

class MyComposite
{
SomeEntity ManyToOne { get; set; }
SomeOtherUserType Value { get; set; }
}

为了便于映射,我做了一个自定义 ICompositeUserType其中包含此组件:
class MyCompositeUserType : ICompositeUserType
{
// ...
private static readonly IType[] _propertyTypes = new[]
{
new ManyToOneType("SomeEntity"),
new CustomType(typeof(SomeOtherUserType))
};
// ...
}

现在,我收藏了 composite-element s 包含此组件:

<class name="Container">
...
<set name="Pairings"
cascade="all-delete-orphan"
generic="true"
lazy="false"
table="Pairings"
fetch="join">
<key column="ContainerId" />
<composite-element class="Pair">
<property name="Item1" type="mycomposite" lazy="false">
<column name="Entity1Id" />
<column name="Amount1" />
</property>
<property name="Item2" type="mycomposite" lazy="false">
<column name="Entity2Id" />
<column name="Amount2" />
</property>
<property name="Tag" column="Tag" />
</composite-element>
</set>
</class>

当我在 Container 上查询时类, Pairings set 被急切地加载,按照设计,但是,然后我在 SomeEntity 上得到了 N+1 选择它构成了 MyCompositeUserType 的一部分.我想加载这些实体以及 Pairings 上的连接。放。

如何指定?

最佳答案

如果映射为组件,您可以使用 lazy="false"将其映射为多对一,或者应该可以在查询时设置 fetchmode

<composite-element class="Pair">
<component name="Item1">
<many-to-one name="Entity1" column="Entity1Id" />
<property name="Amount" column="Amount1" />
</component>
<component name="Item2">
<many-to-one name="Entity2" column="Entity2Id"/>
<property name="Amount" column="Amount2" />
</component>
<property name="Tag" column="Tag" />
</composite-element>

关于hibernate - 如何避免 "N+1 Select"并为具有多对一的 (N)Hibernate 用户类型指定获取策略?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10359957/

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