- 1、本文档共17页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
hibernate缓存机制分析.pdf
hibernate 缓存机制分析
一、N+1 问题
首先我们来探讨一下 N+1 的问题,我们先通过一个例子来看一下,什么是 N+1 问题:
list()获得对象:
/**
* 此时会发出一条 sql ,将30 个学生全部查询出来
*/
ListStudent ls = (ListStudent)session.createQuery(from Student)
.setFirstResult(0).setMaxResults(30).list();
IteratorStudent stus = ls.iterator();
for(;stus.hasNext();)
{
Student stu = (Student)stus.next();
System.out.println(stu.getName());
}
如果通过 list()方法来获得对象,毫无疑问,hibernate 会发出一条 sql 语句,将所有的对象查询出来,这点相信大家都能理
解
Hibernate: select student0_.id as id2_, student0_.name as name2_, student0_.rid as rid2_, student0_.sex as sex2_
from t_student student0_ limit ?
那么,我们再来看看 iterator()这种情况
iterator()获得对象
/**
* 如果使用 iterator 方法返回列表,对于 hibernate 而言,它仅仅只是发出取 id 列表的 sql
* 在查询相应的具体的某个学生信息时,会发出相应的SQL 去取学生信息
* 这就是典型的 N+1 问题
* 存在 iterator 的原因是,有可能会在一个 session 中查询两次数据,如果使用 list 每一次都会把所有的对象
查询上来
* 而是要 iterator 仅仅只会查询 id ,此时所有的对象已经存储在一级缓存(session 的缓存)中,可以直接获取
*/
IteratorStudent stus = (IteratorStudent)session.createQuery(from Student)
.setFirstResult(0).setMaxResults(30).iterate();
for(;stus.hasNext();)
{
Student stu = (Student)stus.next();
1 / 17
System.out.println(stu.getName());
}
在执行完上述的测试用例后,我们来看看控制台的输出,看会发出多少条 sql 语句:
Hibernate: select student0_.id as col_0_0_ from t_student student0_ limit ?
Hibernate: select student0_.id as id2_0_, student0_.name as name2_0_, student0_.rid as rid2_0_, student0_.sex as
sex2_0_ from t_student student0_ where student0_.id=?
Hibernate: select student0_.id as id2_0_, student0_.name
文档评论(0)