我的对象模型有点复杂,形成了一个三角形。存在具有和User
集合的实体。也有分类法。为了方便起见,我想知道它的主人,如果有的话。见图:Items
Taxonomies
Item
Item
Taxonomy
Taxonomy
Item
所以这产生了三个双向关系。我的问题是当我像这样在 NHibernate 中映射它并要求具有给定 ID 的用户时,我遇到了Select N+1问题。
起初,User
加载的是热切的 fetched Items
。然后Taxonomies
加载与Item
它连接的热切获取。这是预期的并且在映射中定义。但是现在有 N+1 个查询要加载Items
与Taxonomies
.
这是多余的,因为对象图的所有部分都已加载。当我从侧面使我的User-Item
关系单向时,这个问题就消失了User
(正如预期的那样,只有 2 个查询),但我不想删除这种反向关系。是否可以对所有三种关系进行双向优化获取?
这是我的映射部分:
public class UserOverride : IAutoMappingOverride<User>
{
public void Override(AutoMapping<User> mapping)
{
mapping.HasMany(x => x.Items).Inverse()
.Not.LazyLoad().Fetch.Join();
mapping.HasMany(x => x.Taxonomies).Inverse()
.LazyLoad().Fetch.Select();
}
}
public class ItemOverride : IAutoMappingOverride<Item>
{
public void Override(AutoMapping<Item> mapping)
{
mapping.References(x => x.Taxonomy); // many-to-one
}
}
public class TaxonomyOverride : IAutoMappingOverride<Taxonomy>
{
public void Override(AutoMapping<Taxonomy> mapping)
{
mapping.HasOne(x => x.Item).PropertyRef(x => x.Taxonomy)
.Not.LazyLoad().Fetch.Join();
}
}
我以最简单的方式查询我的数据库:
var user = session.Get<User>(1);