日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Hibernate的一級(jí)Cache

Hibernate Cache有很多值得學(xué)習(xí)的地方,這里我們主要介紹一級(jí)Cache,包括介紹Session實(shí)現(xiàn)了***級(jí)Hibernate Cache,它屬于事務(wù)級(jí)數(shù)據(jù)緩沖等方面。

公司主營業(yè)務(wù):成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出高安免費(fèi)做網(wǎng)站回饋大家。

Hibernate實(shí)現(xiàn)了良好的Cache機(jī)制,可以借助Hibernate內(nèi)部的Cache迅速提高系統(tǒng)的數(shù)據(jù)讀取性能。Hibernate中的Cache可分為兩層:一級(jí)Cache和二級(jí)Cache.

一級(jí)Cache:

Session實(shí)現(xiàn)了***級(jí)Hibernate Cache,它屬于事務(wù)級(jí)數(shù)據(jù)緩沖。一旦事務(wù)結(jié)束,這個(gè)Cache也隨之失效。一個(gè)Session的生命周期對(duì)應(yīng)一個(gè)數(shù)據(jù)庫事務(wù)或一個(gè)程序事務(wù)。

Session-cache保證了一個(gè)Session中兩次請(qǐng)求同一個(gè)對(duì)象時(shí),取得的對(duì)象是同一個(gè)JAVA實(shí)例,有時(shí)它可以避免不必要的數(shù)據(jù)沖突。另外,它還能為另一些重要的性能提供保證:

1:在對(duì)一個(gè)對(duì)象進(jìn)行自我循環(huán)引用時(shí), 不至于產(chǎn)生堆棧溢出。

2:當(dāng)數(shù)據(jù)庫事務(wù)結(jié)束時(shí),對(duì)于同一個(gè)數(shù)據(jù)庫行,不會(huì)產(chǎn)生數(shù)據(jù)沖突,因?yàn)閷?duì)于數(shù)據(jù)庫中的一行,最多只有一個(gè)對(duì)象來表示它。

3:一個(gè)事務(wù)中可能會(huì)有很多個(gè)處理單元,在每一個(gè)處理單元中做的操作都會(huì)立即被另外的處理單元得知。

我們不用刻意去打開Session-cache,它總是被打開并且不能被關(guān)閉。當(dāng)使用save(),update()或saveOrUpdate()來保存數(shù)據(jù)更改,或通過load(),find(),list()等方法來得到對(duì)象時(shí),對(duì)象就會(huì)被加入到Session-cache.

如果要同步很多數(shù)據(jù)對(duì)象,就需要有效地管理Cache,可以用Session的evict()方法從一級(jí)Cache中移除對(duì)象。如下:

 
 
 
  1. Session session = HibernateUtil.currentSession();  
  2. Transaction tx = session.beginTransaction();  
  3. for(int i = 0 ; i <100000 ; i++)  
  4. {  
  5. Student stu = new Student();  
  6. session.save(stu);  
  7. }  
  8. tx.commit(); 

session.close();在保存50000個(gè)或更多對(duì)象時(shí),程序可能會(huì)拋出OutOfMemoryException異常,因?yàn)镠ibernate Cache在一級(jí)緩存了新加入的所有對(duì)象。內(nèi)存溢出。要解決這全問題就需要把JDBC批處理數(shù)量設(shè)置為一個(gè)合理的數(shù)值(一般是10~20)。在Hibernate Cache的配置文件中可以加入以下屬性

 
 
 
  1.  name="hibernate.jdbc.batch_size"> 20  

然后我們?cè)诔绦蛑幸欢〞r(shí)刻就提交并更新Session的Hibernate Cache:

 
 
 
  1. Session session = HibernateUtil.currentSession();  
  2. Transaction tx = session.beginTransaction();  
  3. for(int i = 0 ; i <100000 ; i++)  
  4. {  
  5. Student stu = new Student();  
  6.  
  7. session.save(stu);  
  8. if(i%20 == 0)//每保存完20個(gè)對(duì)象后,進(jìn)行如下操作  
  9. {  
  10. session.flush();//這個(gè)會(huì)提交更新  
  11. session.clear();//清除Cache,釋放內(nèi)存  
  12. }  

分享名稱:Hibernate的一級(jí)Cache
當(dāng)前URL:http://www.5511xx.com/article/cdppjhj.html