偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

介紹Hibernate Iterator方法

開發(fā) 后端
這里介紹Hibernate Iterator方法,Hibernate提供了可供選擇的一些方式,但具體使用什么方式,可能用性能/代碼都會(huì)有影響。

Hibernate有很多值得學(xué)習(xí)的地方,這里我們主要介紹Hibernate Iterator方法,包括介紹事務(wù)控制等方面。

Hibernate Iterator方法

1.完成同樣一件事,Hibernate提供了可供選擇的一些方式,但具體使用什么方式,可能用性能/代碼都會(huì)有影響。顯示,一次返回十萬條記錄(List /Set/Bag/Map等)進(jìn)行處理,很可能導(dǎo)致內(nèi)存不夠的問題,而如果用基于游標(biāo)(ScrollableResults)或Iterator的結(jié)果集,則不存在這樣的問題。

2.Session的load/get方法,前者會(huì)使用二級(jí)緩存,而后者則不使用。

3.Query和list/Iterator,如果去仔細(xì)研究一下它們,你可能會(huì)發(fā)現(xiàn)很多有意思的情況,二者主要區(qū)別(如果使用了Spring,在HibernateTemplate中對(duì)應(yīng)find,Hibernate Iterator方法):

◆list只能利用查詢緩存(但在交易系統(tǒng)中查詢緩存作用不大),無法利用二級(jí)緩存中的單個(gè)實(shí)體,但list查出的對(duì)象會(huì)寫入二級(jí)緩存,但它一般只生成較少的執(zhí)行SQL語句,很多情況就是一條(無關(guān)聯(lián))。

◆Iterator則可以利用二級(jí)緩存,對(duì)于一條查詢語句,它會(huì)先從數(shù)據(jù)庫中找出所有符合條件的記錄的ID,再通過ID去緩存找,對(duì)于緩存中沒有的記錄,再構(gòu)造語句從數(shù)據(jù)庫中查出,因此很容易知道,如果緩存中沒有任何符合條件的記錄,使用Iterator會(huì)產(chǎn)生N+1條SQL語句(N為符合條件的記錄數(shù))

◆通過Hibernate Iterator,配合緩存管理API,在海量數(shù)據(jù)查詢中可以很好的解決內(nèi)存問題,如:

  1. while(it.hasNext()){  
  2. YouObject object = (YouObject)it.next();  
  3. session.evict(youObject);  
  4. sessionFactory.evice(YouObject.class, youObject.getId());  

事務(wù)控制

事務(wù)方面對(duì)性能有影響的主要包括:事務(wù)方式的選用,事務(wù)隔離級(jí)別以及鎖的選用

1.事務(wù)方式選用:如果不涉及多個(gè)事務(wù)管理器事務(wù)的話,不需要使用JTA,只有JDBC的事務(wù)控制就可以。

2.事務(wù)隔離級(jí)別:參見標(biāo)準(zhǔn)的SQL事務(wù)隔離級(jí)別

3.鎖的選用:悲觀鎖(一般由具體的事務(wù)管理器實(shí)現(xiàn)),對(duì)于長事務(wù)效率低,但安全。樂觀鎖(一般在應(yīng)用級(jí)別實(shí)現(xiàn)),如在Hibernate中可以定義 VERSION字段,顯然,如果有多個(gè)應(yīng)用操作數(shù)據(jù),且這些應(yīng)用不是用同一種樂觀鎖機(jī)制,則樂觀鎖會(huì)失效。因此,針對(duì)不同的數(shù)據(jù)應(yīng)有不同的策略,同前面許多情況一樣,很多時(shí)候我們是在效率與安全/準(zhǔn)確性上找一個(gè)平衡點(diǎn),無論如何,優(yōu)化都不是一個(gè)純技術(shù)的問題,你應(yīng)該對(duì)你的應(yīng)用和業(yè)務(wù)特征有足夠的了解。

【編輯推薦】

  1. 描述Hibernate持久性類
  2. 分析Java應(yīng)用程序和Hibernate
  3. Hibernate3和JBOSS 3.2強(qiáng)強(qiáng)聯(lián)手
  4. 詳解Hibernate.properties文件
  5. 淺談定制Hibernate映射
責(zé)任編輯:佚名 來源: IT168
相關(guān)推薦

2009-06-12 16:00:13

Session方法Hibernate

2009-09-22 09:27:29

Hibernate P

2009-09-28 13:49:44

Hibernate Q

2009-09-25 13:55:05

Hibernate使用

2009-09-23 17:41:05

Hibernate事務(wù)

2009-09-25 09:46:03

Hibernate s

2009-09-28 10:24:58

Hibernate基礎(chǔ)

2009-06-17 11:18:02

Hibernate延遲

2009-09-22 10:57:42

Hibernate專業(yè)

2009-09-27 14:24:10

Hibernate配置

2009-06-25 16:52:34

2009-09-21 14:50:01

Hibernate部署

2009-09-24 10:13:05

Hibernate版本

2009-09-27 10:10:47

Hibernate處理

2009-06-05 10:48:01

struts2 ite功能

2009-09-25 17:19:28

Hibernate持久

2009-06-12 15:09:01

Hibernate優(yōu)化

2009-09-23 09:47:23

Hibernate e

2009-09-23 16:54:08

Hibernate修改

2009-06-16 16:27:22

Hibernate優(yōu)化
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)