hibnerate criteria set 查询N+1问题

本文探讨了在使用Hibernate时,遇到Set集合关联查询导致的N+1问题,通过分析发现使用INNER_JOIN可能导致性能瓶颈,而将JOIN方式改为LEFT_JOIN可以有效解决此问题。同时,对比了HQL查询对此问题的不同处理方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

类中存在Set集合的变量,在*.hbm.xml中一般配置为一对多的关联,并且lazy配置为true,

但是在Criteria createAlias("variableName", "variableAlias", Criteria.INNER_JOIN);

INNER_JOIN并不会起作用,需要用Hibernate.initialize进行初始化,导致N+1问题。

但是把INNER_JOIN变成LEFT_JOIN的话

Criteria createAlias("variableName", "variableAlias", Criteria.LEFT_JOIN); 是可以把Set关联的查询上来。这是Hibernate 的一个bug.

另外用HQL inner join不存在这个问题。
     

[参考]https://forum.hibernate.org/viewtopic.php?p=2418532

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值