轉帖|其它|編輯:郝浩|2011-01-21 13:25:17.000|閱讀 592 次
概述:本文主要對Hibernate查詢緩存作一個全面分析,希望對大家有幫助。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
緩存分類:
◆一級緩存Session級
◆二級緩存SessionFactory級別 JVM級別
Hibernate查詢緩存不固定(根據生命周期 來說 不固定)
生命周期:
◆一級緩存 是和 session 會話一直 產生一直消失
◆二級緩存 是和 sessionFacotry 一致
Hibernate查詢緩存 生命周期不固定 ,當數據庫 表發生改變的使用Hibernate查詢緩存馬上消失
使用方法:
◆一級緩存:這個就不用說了
◆二級緩存:首先拷貝 使用Hibernate查詢緩存類別.xml到 classpath目錄下面,然后 到hibernate.cfg.xml里面配置。開啟二級緩存(默認開啟),定義要使用二級緩存的實體類,然后 就是在程序中要顯示的指定session。
使用二級緩存的類別 有三種,Normal,GET,PUT默認使用的是 Normal即可以寫也可以讀取二級緩存(這里讀寫是指的會話Session)
Hibernate查詢緩存:首先也是到hibernate配置文件中去開啟Hibernate查詢緩存,然后程序中也 要顯示的調用方法來開啟Hibernate查詢緩存eg:query.setCachemodel(true);
緩存的保存對象:
◆一級緩存:緩存的是 實體
◆二級緩存 緩存的也是實體
Hibernate查詢緩存緩存的是 查詢出來的 實體的部分屬性結果集 和 實體的ID (注意這里不是實體)
緩存的使用對象:
◆一級緩存:
Load(Lazy加載) 使用一級緩存當load的使用 首先查找把序列號去和一級緩存匹配是否有,就直接取出來如果沒有 就發出SQL語句。
Get也使用一級緩存。
List接口 query.list() 不使用 一級緩存每次 都要發出SQL eg:(select * from tudent)。Iterator 接口 query.iterate();使用一級緩存 首先是要發出一條SQL 來取得ID,eg: select。id from student; 然后 把ID 拿到緩存中去匹配 如果有 就直接取 如果沒有,就要再發出SQL如果 都沒有 將發出N+1條SQL這就是N+1問題
◆二級緩存: 都使用了二級緩存
Hibernate查詢緩存:看到名字 顧名思義就知道 是查詢 那么就是對List 和Iterator接口起作用
但是Hibernate查詢緩存對Iterator不起作用,只對List起作用。
下面我們這種介紹把二級緩存 和 Hibernate查詢緩存 結合使用
當只是用Hibernate查詢緩存 而關閉 二級緩存的時候:
第一:如果查詢的是部分屬性結果集:
那么當第二次查詢的時候 就不會發出SQL 直接從Hibernate查詢緩存中取數據 第二:如果查詢的是 實體結果集eg(from Student) 這個HQL 那么 查詢出來的實體,首先Hibernate查詢緩存 存放實體的ID ,
第二次查詢的時候 就到Hibernate查詢緩存中取出ID 一條一條的到數據庫查詢 這樣 將發出N 條SQL造成了SQL泛濫
當都開啟Hibernate查詢緩存和二級緩存的時候
第一:如果查詢的是部分屬性結果集: 這個和上面只是用Hibernate查詢緩存 而關閉 二級緩存的時候,一致 因為不涉及實體 不會用到二級緩存
第二:如果查詢的是 實體結果集eg(from Student) 這個HQL 那么 查詢出來的實體,首先Hibernate查詢緩存 存放實體的ID,第二次查詢,的時候 就到Hibernate查詢緩存中取出ID,拿到二級緩存區找數據,如果有數據 就不會發出SQL 如果都有 一條SQL 都不會發出 直接從二級緩存中取數據。
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自:網絡轉載