文档章节

Fetch与Cache

猪刚烈
 猪刚烈
发布于 2014/10/12 11:40
字数 587
阅读 34
收藏 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

 

 

 


猪刚烈

猪刚烈

粉丝 22
博文 708
码字总数 110
作品 1
海淀
程序员
私信 提问
加载中
请先登录后再评论。
Go-node

Go-node 是一个用 Go 语言实现的 Erlang/OTP node 已支持的功能: Publish listen port via EPMD Handle incoming connection from other node using Erlang Distribution Protocol Spawn E......

匿名
2013/01/25
1.5K
1
PHP框架--XiunoPHP

XiunoPHP 是一款面向高负载应用的 PHP 开发框架,PHPer 通过它可以快速的简单的开发出高负载项目。 XiunoPHP 前身名为 Xiuno Framework,更名后版本号从 v1.0 开始计算。已经经过了多年的实际...

匿名
2013/03/20
2.5K
0
使用IBPP在C++中操作FireBird/Interbase数据库

FireBird是一种小巧的关系型数据库,它有多种版本,包括服务器版(象MySQL),单机版(象Access)以及嵌入式(象SQLite)。而且不管是服务器版还是嵌入式版它都完整支持视图、触发器、存储过程等...

Waiting4you
2009/07/26
3.8K
2
SmartGWT学习整理 2、理解核心中的核心DataSource

SmartGWT学习整理 2、理解核心中的核心DataSource DataSource之所以重要,是因为它负责所有的与服务器的数据交互,几乎所有的控件都离不开它。 可以这样说,理解了DataSource就掌握了SmartGW...

st97
2010/11/16
2K
2
深度吐槽hibernate

hibernate我很久都没有用了,最后一次用应该是3年前的一个企业项目,决定采用hibernate的并不是我,是我领导,我只是开发者。我所受的罪领导并不知道。正如我的每个hibernate项目那样,每次我...

闲大赋
2015/12/23
5.3K
56

没有更多内容

加载失败,请刷新页面

加载更多

将32位循环计数器替换为64位会在Intel CPU上使用_mm_popcnt_u64引起疯狂的性能偏差

问题: I was looking for the fastest way to popcount large arrays of data. 我一直在寻找最快的方法来popcount大量数据的数量。 I encountered a very weird effect: Changing the loop......

javail
32分钟前
12
0
什么是单子? - What is a monad?

问题: Having briefly looked at Haskell recently, what would be a brief, succinct, practical explanation as to what a monad essentially is? 最近对Haskell进行了简要介绍之后,关于......

富含淀粉
今天
19
0
是什么 做?

问题: What's the difference if one web page starts with 如果一个网页以...开头有什么区别 <!DOCTYPE html> <html> <head> <meta http-equiv="X-UA-Compatible" content="IE=ed......

技术盛宴
今天
15
0
我怎样才能存储特定文件? [重复] - How can I git stash a specific file? [duplicate]

问题: Possible Duplicate: 可能重复: How to stash only one file out of multiple files that have changed 如何从已更改的多个文件中仅存储一个文件 How can I stash a specific file ......

法国红酒甜
今天
36
0
OSChina 周一乱弹 —— 你想用屁治疗一下谁

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: 《Rain in the Park》- Marika Takeuchi 手机党少年们想听歌,请使劲儿戳(这里)...

小小编辑
今天
99
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部