Hiberante3 一級緩存總結(jié)
1. Session 級別的緩存,它同session邦定。它的生命周期和session相同。Session消毀,它也同時消毀;管理一級緩存,一級緩存無法取消,用兩個方法管理,clear(),evict()
2. 兩個session 不能共享一級緩存,因它會伴隨session的生命周期的創(chuàng)建和消毀;
3. Session緩存是實體級別的緩存,就是只有在查詢對象級別的時候才使用,如果
使用HQL和SQL是查詢屬性級別的,是不使用一級緩存的!切記!!!!
4 . iterate 查詢使用緩存,會發(fā)出查詢Id的SQL和HQL語句,但不會發(fā)出查實體的,
它查詢完會把相應(yīng)的實體放到緩存里邊,一些實體查詢?nèi)绻彺胬镞呌校蛷木彺嬷胁樵儯€是會發(fā)出查詢id的SQL和HQL語句。如果緩存中沒有它會數(shù)據(jù)庫中查詢,然后將查詢到的實體一個一個放到緩存中去,所以會有N+1問題出現(xiàn)。
5 . List()和iterate 查詢區(qū)別:
使用iterate,list查詢實體對象*N+1問題,在默認(rèn)情況下,使用query.iterate查詢,有可以能出現(xiàn)N+1問題
所謂的N+1是在查詢的時候發(fā)出了N+1條sql語句1:首先發(fā)出一條查詢對象id列表的sqlN:
根據(jù)id列表到緩存中查詢,如果緩存中不存在與之匹配的數(shù)據(jù),那么會根據(jù)id發(fā)出相應(yīng)的sql語句list和iterate的區(qū)別?
list每次都會發(fā)出sql語句,list會向緩存中放入數(shù)據(jù),而不利用緩存中的數(shù)據(jù)
iterate:在默認(rèn)情況下iterate利用緩存數(shù)據(jù),但如果緩存中不存在數(shù)據(jù)有可以能出現(xiàn)N+1問題
6.Get()和load(),iterate方法都會使用一級緩存,
7.hiberate3 session 存儲過程如下:
例如 object 對象
Session.save(object);
這時候不會把數(shù)據(jù)放到數(shù)據(jù)庫,會先放到session緩存中去,數(shù)據(jù)庫中沒有相應(yīng)記錄,session.flush();才發(fā)SQL和HQL語句,數(shù)據(jù)庫中有了相應(yīng)記錄,
但是數(shù)據(jù)庫用select查不到,這是跟數(shù)據(jù)庫事物級別有關(guān)系,(這里在說下數(shù)據(jù)庫的事務(wù)隔離級別一共四種如下:)
數(shù)據(jù)庫隔離級別:
隔離級別 是否存在臟讀 是否存在不可重復(fù)讀 是否存在幻讀;
Read UnCommited(未提交讀) Y Y Y
Read Commited (提交讀 oraclel默認(rèn)) N Y Y
Repeatable Read(不可重復(fù)讀(Msql默認(rèn))) N N Y
Serializable(使用很少) N N N
Session.beginTrransaction().commit();
事物提交后可以查詢到了。
Session.flush()語句但是為什么不寫呢,因為commit()會默認(rèn)調(diào)用flush();
Hiberante3 二級緩存總結(jié)
1.Hibernate3的(sessionFactory)二級緩存和session級別的緩存一樣都只對實體對象做緩存,不對屬性級別的查詢做緩存;二級緩存的生命周期和sessionFactory的生命周期是一樣的,sessionFactory可以管理二級緩存;
2.sessionFactory級別的緩存,需要手動配置;所有的session可以共享sessionFactory 級別的緩存;(一般把一些不經(jīng)常變化的實體對象放到sessionFactory級別的緩存中,適合放不經(jīng)常變化的實體對象。)
3.Hiberante3二級緩存的配置和使用方法如下:
1. 必須把ehcache.jar包導(dǎo)入,然后到Hibernate3.2的etc文件下把ehcache.xml復(fù)制到工程src目錄下(ehcache.xml里邊的參數(shù)里邊有詳細(xì)英文說明);
(說明:ehcache.jar是第三方法的緩存產(chǎn)品,hiberante只是把它做了集成,還有好多第三方hibernate集成的緩存產(chǎn)品,相關(guān)說明請查閱hiberante3開發(fā)手冊;ehcache支持分布應(yīng)用的(這個和Hibernate3.2開發(fā)手冊有出入,經(jīng)過官網(wǎng)查證確實支持了),如果有分布式需求,請換成支持分布式的二級緩存產(chǎn)品,hiberate3開發(fā)手冊都有相頭說明。配置方法都類似);
4.Hibernate3的二級緩存默認(rèn)是開起的,也可以指定開起。在hibernate.cfg.xml 文件下配置如下:
*修改hibernate.cfg.xml文件,開戶二級緩存;
<property name=”hibernate.cache.use_second_level_cache”>true</property>
*指定二級緩存產(chǎn)品的提供商;
<property name=”hibernate.cache.provider_class”> org.hibernate.cache.EhCacheProvider
</property>
要讓那些實體使用二級緩存,在hibernate.cfg.xml配置文件中加入:
<!—
讓這個實體用二級緩存 也可以在實體中映射文件去配置即:
<cache usage="read-only"/>
-->
<class-cache class=”com.zzz.hibernate.ClassT” usage=”read-only”/>
Read-only一般使用這個策略,其它的hibernate3開發(fā)手冊中也有詳細(xì)介紹;
CacheMode去hibernate3開發(fā)手冊中搜索這個關(guān)鍵字,可以找到一級緩存和二級緩存交互使用的問題;