hibernate缓存机制分析.pdfVIP

  1. 1、本文档共17页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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)

zhoujiahao + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档