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