文档章节

Fetch与Cache

猪刚烈
 猪刚烈
发布于 2014/10/12 11:40
字数 587
阅读 5
收藏 0

通过测试我发现,通过Fetch得去的对象是不会放入二级缓存的!(但它极有可能被放入查询缓存!这一点明天研究一下。)凡是Fetch的对象都会通过生成SQL从数据库重建。这一点和 http://blog.csdn.net/bluishglc/archive/2010/05/16/5597043.aspx 中所提到的情况暗合!为什么说“暗合”呢?目前来看,我们可以认为:在Hibernate中Fetch出来的对象似乎总是“二等公民”,它们只被它们的宿主对象所知,从全局的角度(Session)是看不到这些对象的。(是这样的么?明天做一下测试。搞明白session和session的缓存一回事么?)这就是为什么这些被Fetch的对象明明已经加载到了内存中,但是在二级缓存中却找不它们。反面的印证就是从宿主对象导航到Fetch出来的从属对象时并不会导致SQL产生,但如果从属对象不是通过Fetch加载的,即使它们之前已被加载出来,在导航到这些对象时还是生成SQL的。(此时正是使用二级缓存的好时机,如果使用的话,就不会生成SQL了!)这就是Fetch和二级缓存之间微妙的关系。

 

记住非常重要的一点:

通过load,get和对象间导航得到的对象都是二级缓存的目标!通过查询得到的对象是不会进行二级缓存的,而是进入查询缓存!


做一个测试:先通过HQL查询一个对象。然后使用load得到这个对象,在使用二级缓存的情况下,看一看是什么结果!

 

查询中产生的对象会进入Session上下文。此时如果通过session来load这些对象会直接命中,不会生成SQL。

但是查询本身不会试图从上下文中查找对象。而是必定生成SQL。

 

例子:

        //The hql is: from Thread
        threadRepository.loadAll();
        logger.debug("ALL");
        threadRepository.load(1L);
        logger.debug("1 L");
        threadRepository.load(2L);
        logger.debug("2 L");

结果:

DEBUG - SQLStatementLogger.logStatement(111) |
    /* criteria query */ select
        this_.id as id5_0_,
        this_.creationTime as creation2_5_0_,
        this_.forumId as forumId5_0_,
        this_.modifiedTime as modified3_5_0_,
        this_1_.subjectId as subjectId6_0_
    from
        Thread this_
    left outer join
        Thread_Subject this_1_
            on this_.id=this_1_.threadId
DEBUG - ForumTest.testGetForumById(37) | ALL
DEBUG - ForumTest.testGetForumById(39) | 1 L
DEBUG - ForumTest.testGetForumById(41) | 2 L

 

 

 


本文转载自:http://blog.csdn.net/bluishglc/article/details/5659202

共有 人打赏支持
猪刚烈
粉丝 22
博文 708
码字总数 110
作品 1
海淀
程序员
私信 提问
5、Approximate timing for various operations on a typical PC

execute typical instruction 1/1,000,000,000 sec = 1 nanosec fetch from L1 cache memory 0.5 nanosec branch misprediction 5 nanosec fetch from L2 cache memory 7 nanosec Mutex lock......

hopegrace
2012/03/29
0
0
discuz 首页四格图不显示的解决方法

低版本升级导致,preforumthreadimage 表格为空 代码有bug,按如下修改代码: ~~~.phpdiff --git a/source/module/forum/forumindex.php b/source/module/forum/forumindex.phpindex 3bc08e5......

扣丁禅师
2016/05/31
15
0
执行apt-get upgrade遇到的错误

Failed to fetch http://172.16.19.246/ubuntu_precise_163/pool/main/g/gcc-4.4/libstdc++6_4.4.3-4ubuntu5.1_i386.deb rename failed, Input/output error (/var/cache/apt/archives/parti......

yandong
2013/01/15
825
2
典型 PC 系统各种操作指令的大概时间

典型 PC 系统各种操作指令的大概时间 参考: http://news.cnblogs.com/n/155744/

hopegrace
2012/09/02
0
0
Workbox 3:Service Worker 可以如此简单

如果你追求极致的 Web 体验,你一定在站点中使用过 PWA,也一定面临过在编写 Service Worker 代码时的犹豫不决,因为 Service Worker 太重要了,一旦注册在用户的浏览器,全站的请求都会被 ...

作者: 虚笔
08/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

大数据教程(9.5)用MR实现sql中的jion逻辑

上一篇博客讲解了使用jar -jar的方式来运行提交MR程序,以及通过修改YarnRunner的源码来实现MR的windows开发环境提交到集群的方式。本篇博主将分享sql中常见的join操作。 一、需求 订单数据表...

em_aaron
8分钟前
0
0
十万个为什么之什么是resultful规范

起源 越来越多的人开始意识到,网站即软件,而且是一种新型的软件。这种"互联网软件"采用客户端/服务器模式,建立在分布式体系上,通过互联网通信,具有高延时(high latency)、高并发等特点...

尾生
13分钟前
0
0
《告诉你真实的美国教育》的读后感3900字

《告诉你真实的美国教育》的读后感3900字: 文章的开篇分析了我们耳熟能详的关于美国教育的小故事,就是那个因为幼儿园的老师教了“0”这个字母,然后妈妈告老师剥夺了孩子的想象力,再然后幼...

原创小博客
22分钟前
0
0
Terraform配置文件(Terraform configuration)

Terraform配置文件 翻译自Terraform Configuration Terraform用文本文件来描述设备、设置变量。这些文件被称为Terraform配置文件,以.tf结尾。这一部分将讲述Terraform配置文件的加载与格式。...

buddie
37分钟前
1
0
exportfs命令, vsftp搭建ftp服务

exportfs命令 当修改/etc/exports文件后,更改的内容是不会立即生效的。如果重启nfs服务,会导致客户端重启期间的请求是挂起等待的,可以把客户端的挂载umount进行卸载后,再重启nfs服务,但...

野雪球
47分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部