hibnerate criteria set 查询N+1问题

类中存在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、付费专栏及课程。

余额充值