真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Hibernate如何實現(xiàn)一級Cache

這篇文章主要為大家展示了“Hibernate如何實現(xiàn)一級Cache”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Hibernate如何實現(xiàn)一級Cache”這篇文章吧。

創(chuàng)新互聯(lián)是一家朝氣蓬勃的網(wǎng)站建設(shè)公司。公司專注于為企業(yè)提供信息化建設(shè)解決方案。從事網(wǎng)站開發(fā),網(wǎng)站制作,網(wǎng)站設(shè)計,網(wǎng)站模板,微信公眾號開發(fā),軟件開發(fā),微信平臺小程序開發(fā),10多年建站對成都宣傳片制作等多個方面,擁有豐富的網(wǎng)站運維經(jīng)驗。

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

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

一級Cache:

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

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

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

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

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

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

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

Session session = HibernateUtil.currentSession();  Transaction tx = session.beginTransaction();  for(int i = 0 ; i <100000 ; i++)  {  Student stu = new Student();  session.save(stu);  }  tx.commit();

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

 20 

然后我們在程序中一定時刻就提交并更新Session的Hibernate Cache:

Session session = HibernateUtil.currentSession();  Transaction tx = session.beginTransaction();  for(int i = 0 ; i <100000 ; i++)  {  Student stu = new Student();   session.save(stu);  if(i%20 == 0)//每保存完20個對象后,進行如下操作  {  session.flush();//這個會提交更新  session.clear();//清除Cache,釋放內(nèi)存  }  }

以上是“Hibernate如何實現(xiàn)一級Cache”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


本文標(biāo)題:Hibernate如何實現(xiàn)一級Cache
分享網(wǎng)址:http://weahome.cn/article/pppegg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部