Hibernate(九)--N+1问题

本文探讨了在使用Hibernate操作数据库时可能出现的N+1问题,特别是在实体类上设置了表的双向关联的情况下。文章详细解释了一对多和多对一关联如何导致此问题,并提供了两种解决方案:一是使用延迟检索策略来避免不必要的关联对象加载;二是采用迫切左外连接检索策略,通过一次SQL外连接查询来减少select语句的数量。
摘要由CSDN通过智能技术生成

1、在利用Hibernate操作数据库的时候,如果在实体类上设置了表的双向关联.这可能会出现Hibernate N+1的问题.

 

        1.1、一对多: 

                   在一方,查找得到了 n 个对象,那么又需要将 n 个对象关联的集合取出,于是本来的一条 sql 查询变成了 n+1 条;

         1.2、多对一: 

                  在多方,查询得到了 m 个对象,那么也会将 m 个对象对应的 1 方的对象取出, 也变成了 m+1 ;

 

 

 

2、关于Hibernate N+1的解决方法

 

2.1 延迟检索策略能避免多余加载应用程序不需要访问的关联对象

Hibernate3开始已经默认是lazy=true了;lazy=true时不会立刻查询关联对象,只有当需要关联对象(访问其属性)时才会发生查询动作。

 

2.2迫切左外连接检索策略则充分利用了SQL的外连接查询功能,能够减少select语句的数目

可以在映射文件里面配置下面的抓取策略

 

 
<set name="ordes" fetch="join">
 
  <key column="customer_id" />
 
  <one-to-many class="Order" />
 
</set>

  fetch参数指定了关联对象抓取的方式是select查询还是join查询,select方式时先查询返回要查询的主体对象(列表),再根据关联外键id,每一个对象发一个select查询,获取关联的对象,形成n+1次查询;
  而join方式,主体对象和关联对象用一句外键关联的sql同时查询出来,不会形成多次查询。
  如果你的关联对象是延迟加载的,它当然不会去查询关联对象。
  另外,在hql查询中配置文件中设置的join方式是不起作用的(而在所有其他查询方式如get、criteria或再关联获取等等都是有效的),会使用select方式,除非你在hql中指定join fetch某个关联对象。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值