首页 > Web开发 > 详细

Hibernate “N+1”查询问题

时间:2016-07-31 18:57:56      阅读:340      评论:0      收藏:0      [点我收藏+]

Hibernate 默认情况下使用立即检索策略,即从数据库加载A对象时  会同时加载跟它关联的B,这样产生了不必要的对象集合查询,而且本来可以合并的sql要执行1+N次,因为一条select出所有的A之后,会针对A中每条数据在B检索。

所以Hibernate 提出了两种检索策略改变这种问题:

1:延迟检索:

  H3  避免加载多余的关联对象,设置lazy=true;这样 不会立刻查询关联对象,只有当需要关联对象时才查询。

  session.find("from A as c")

2:外连接查询:

  -->left outer join

  -->set FetchMode(FetchMode.JOIN)

  -->映射文件定义连接抓取方式

Hibernate “N+1”查询问题

原文:http://www.cnblogs.com/newcoder/p/5723464.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!