日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

在Hibernate中獲取數(shù)據(jù)方式與緩存使用 - 開發(fā)者在線 - www.builder....

 tom lee 2008-01-31

在Hibernate中獲取數(shù)據(jù)方式與緩存使用

開發(fā)者在線 Builder.com.cn 更新時(shí)間:2007-11-23作者:dxaw 來源:賽迪網(wǎng)技術(shù)社區(qū)

本文關(guān)鍵詞: 緩存使用 獲取數(shù)據(jù) Hibernate

Hibernate獲取數(shù)據(jù)的方式有不同的幾種,其與緩存結(jié)合使用的效果也不盡相同,而Hibernate中具體怎么使用緩存其實(shí)是我們很關(guān)心的一個問題,直接涉及到性能方面。

緩存在Hibernate中主要有三個方面:一級緩存、二級緩存和查詢緩存;一級緩存在Hibernate中對應(yīng)的即為session范圍的緩存,也就是當(dāng)session關(guān)閉時(shí)緩存即被清除,一級緩存在Hibernate中是不可配置的部分;二級緩存在Hibernate中對應(yīng)的即為SessionFactory范圍的緩存,通常來講SessionFactory的生命周期和應(yīng)用的生命周期相同,所以可以看成是進(jìn)程緩存或集群緩存,二級緩存在Hibernate中是可以配置的,可以通過class-cache配置類粒度級別的緩存(class-cache在class中數(shù)據(jù)發(fā)生任何變化的情況下自動更新),同時(shí)也可通過collection-cache配置集合粒度級別的緩存(collection-cache僅在collection中增加了元素或者刪除了元素的情況下才自動更新,也就是當(dāng)collection中元素發(fā)生值的變化的情況下它是不會自動更新的),緩存自然會帶來并發(fā)的訪問問題,這個時(shí)候相應(yīng)的就要根據(jù)應(yīng)用來設(shè)置緩存所采用的事務(wù)隔離級別,和數(shù)據(jù)庫的事務(wù)隔離級別概念基本一樣,沒什么多介紹的,查詢緩存在Hibernate同樣是可配置的,默認(rèn)是關(guān)閉的,可以通過設(shè)置cache.use_ query_cache為true來打開查詢緩存。根據(jù)緩存的通常實(shí)現(xiàn)策略,我們可以來理解Hibernate的這三種緩存,緩存的實(shí)現(xiàn)通過是通過key/value的Map方式來實(shí)現(xiàn),在Hibernate的一級、二級和查詢緩存也同樣如此,一級、二級緩存使用的key均為po的主鍵ID,value即為po實(shí)例對象,查詢緩存使用的則為查詢的條件、查詢的參數(shù)、查詢的頁數(shù),value有兩種情況,如果采用的是select po.property這樣的方式那么value為整個結(jié)果集,如采用的是from這樣的方式那么value為獲取的結(jié)果集中各po對象的主鍵ID,這樣的作用很明顯,節(jié)省內(nèi)存。

簡單介紹完Hibernate的緩存后,再結(jié)合Hibernate的獲取數(shù)據(jù)方式來說明緩存的具體使用方式,在Hibernate中獲取數(shù)據(jù)常用的方式主要有四種:Session.load、Session.get、Query.list、Query.iterator。

1、Session.load

在執(zhí)行session.load時(shí),Hibernate首先從當(dāng)前session的一級緩存中獲取id對應(yīng)的值,在獲取不到的情況下,將根據(jù)該對象是否配置了二級緩存來做相應(yīng)的處理,如配置了二級緩存,則從二級緩存中獲取id對應(yīng)的值,如仍然獲取不到則還需要根據(jù)是否配置了延遲加載來決定如何執(zhí)行,如未配置延遲加載則從數(shù)據(jù)庫中直接獲取,在從數(shù)據(jù)庫獲取到數(shù)據(jù)的情況下,Hibernate會相應(yīng)的填充一級緩存和二級緩存,如配置了延遲加載則直接返回一個代理類,只有在觸發(fā)代理類的調(diào)用時(shí)才進(jìn)行數(shù)據(jù)庫查詢的操作。

在這樣的情況下我們就可以看到,在session一直打開的情況下,要注意在適當(dāng)?shù)臅r(shí)候?qū)σ患壘彺孢M(jìn)行刷新操作,通常是在該對象具有單向關(guān)聯(lián)維護(hù)的時(shí)候,在Hibernate中可以使用象session.clear、session.evict的方式來強(qiáng)制刷新一級緩存。

二級緩存則在數(shù)據(jù)發(fā)生任何變化(新增、更新、刪除)的情況下都會自動的被更新。

2、Session.get

在執(zhí)行Session.get時(shí),和Session.load不同的就是在當(dāng)從緩存中獲取不到時(shí),直接從數(shù)據(jù)庫中獲取id對應(yīng)的值。

3、Query.list

在執(zhí)行Query.list時(shí),Hibernate的做法是首先檢查是否配置了查詢緩存,如配置了則從查詢緩存中查找key為查詢語句+查詢參數(shù)+分頁條件的值,如獲取不到則從數(shù)據(jù)庫中進(jìn)行獲取,從數(shù)據(jù)庫獲取到后Hibernate將會相應(yīng)的填充一級、二級和查詢緩存,如獲取到的為直接的結(jié)果集,則直接返回,如獲取到的為一堆id的值,則再根據(jù)id獲取相應(yīng)的值(Session.load),最后形成結(jié)果集返回,可以看到,在這樣的情況下,list也是有可能造成N次的查詢的。

查詢緩存在數(shù)據(jù)發(fā)生任何變化的情況下都會被自動的清空。

4、Query.iterator

在執(zhí)行Query.iterator時(shí),和Query.list的不同的在于從數(shù)據(jù)庫獲取的處理上,Query.iterator向數(shù)據(jù)庫發(fā)起的是select id from這樣的語句,也就是它是先獲取符合查詢條件的id,之后在進(jìn)行iterator.next調(diào)用時(shí)才再次發(fā)起session.load的調(diào)用獲取實(shí)際的數(shù)據(jù)。

可見,在擁有二級緩存并且查詢參數(shù)多變的情況下,Query.iterator會比Query.list更為高效。

這四種獲取數(shù)據(jù)的方式都各有適用的場合,要根據(jù)實(shí)際情況做相應(yīng)的決定,最好的方式無疑就是打開show_sql選項(xiàng)看看執(zhí)行的情況來做分析,系統(tǒng)結(jié)構(gòu)上只用保證這種調(diào)整是容易實(shí)現(xiàn)的就好了,在cache這個方面的調(diào)整自然是非常的容易,只需要調(diào)整配置文件里的設(shè)置,而查詢的方式則可對外部進(jìn)行屏蔽,這樣要根據(jù)實(shí)際情況調(diào)整也非常容易。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多