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

被折叠的 条评论
为什么被折叠?



