当前位置: 代码迷 >> Web前端 >> hibnerate criteria set 查询N+1有关问题
  详细解决方案

hibnerate criteria set 查询N+1有关问题

热度:310   发布时间:2013-10-22 16:16:51.0
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