自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

概括Hibernate屬性延遲加載

開(kāi)發(fā) 后端
這里介紹通過(guò)Hibernate屬性延遲加載機(jī)制,來(lái)使我們獲得只有當(dāng)我們真正需要操作這個(gè)字段時(shí),才去讀取這個(gè)字段數(shù)據(jù)的能力,為此我們必須如下配置我們的實(shí)體類。

Hibernate有很多值得學(xué)習(xí)的地方,這里我們主要介紹Hibernate屬性延遲加載,包括介紹CGLIB是Apache的一個(gè)開(kāi)源工程等方面。

延遲加載機(jī)制是為了避免一些無(wú)謂的性能開(kāi)銷而提出來(lái)的,所謂延遲加載就是當(dāng)在真正需要數(shù)據(jù)的時(shí)候,才真正執(zhí)行數(shù)據(jù)加載操作。在Hibernate中提供了對(duì)實(shí)體對(duì)象的延遲加載以及對(duì)集合的延遲加載,另外在Hibernate3中還提供了對(duì)屬性的延遲加載。下面我們就介紹Hibernate屬性延遲加載。

Hibernate屬性延遲加載

在Hibernate3中,引入了一種新的特性——Hibernate屬性延遲加載,這個(gè)機(jī)制又為獲取高性能查詢提供了有力的工具。在前面我們講大數(shù)據(jù)對(duì)象讀取時(shí),在User對(duì)象中有一個(gè)resume字段,該字段是一個(gè) java.sql.Clob類型,包含了用戶的簡(jiǎn)歷信息,當(dāng)我們加載該對(duì)象時(shí),我們不得不每一次都要加載這個(gè)字段,而不論我們是否真的需要它,而且這種大數(shù)據(jù)對(duì)象的讀取本身會(huì)帶來(lái)很大的性能開(kāi)銷。在Hibernate2中,我們只有通過(guò)我們前面講過(guò)的面性能的粒度細(xì)分,來(lái)分解User類,來(lái)解決這個(gè)問(wèn)題(請(qǐng)參照那一節(jié)的論述),但是在Hibernate3中,我們可以通過(guò)Hibernate屬性延遲加載機(jī)制,來(lái)使我們獲得只有當(dāng)我們真正需要操作這個(gè)字段時(shí),才去讀取這個(gè)字段數(shù)據(jù)的能力,為此我們必須如下配置我們的實(shí)體類:

  1. <hibernate-mapping> 
  2. <class name=”com.neusoft.entity.User” table=”user”  
  3. ……  
  4. <property name=”resume”type=”java.sql.Clob”column=”resume” lazy=’true’/> 
  5. </class> 
  6. </hibernate-mapping> 

通過(guò)對(duì)<property>元素的lazy屬性設(shè)置true來(lái)開(kāi)啟Hibernate屬性延遲加載,在Hibernate3中為了實(shí)現(xiàn)屬性的延遲加載,使用了類增強(qiáng)器來(lái)對(duì)實(shí)體類的Class文件進(jìn)行強(qiáng)化處理,通過(guò)增強(qiáng)器的增強(qiáng),將CGLIB的回調(diào)機(jī)制邏輯,加入實(shí)體類,這里我們可以看出屬性的延遲加載,還是通過(guò)CGLIB來(lái)實(shí)現(xiàn)的。CGLIB是Apache的一個(gè)開(kāi)源工程,這個(gè)類庫(kù)可以操縱java類的字節(jié)碼,根據(jù)字節(jié)碼來(lái)動(dòng)態(tài)構(gòu)造符合要求的類對(duì)象。根據(jù)上面的配置我們運(yùn)行下面的代碼:

  1. String sql=”from User user where user.name=’zx’ ”;  
  2. Query query=session.createQuery(sql)  
  3. List list=query.list();  
  4. for(int i=0;i<list.size();i++){  
  5. User user=(User)list.get(i);  
  6. System.out.println(user.getName());  
  7. System.out.println(user.getResume());  

當(dāng)執(zhí)行到第二行時(shí),會(huì)生成類似如下的SQL語(yǔ)句:

  1. Select id,age,name from user where name=’zx’; 

這時(shí)Hibernate會(huì)檢索User實(shí)體中所有非延遲加載屬性對(duì)應(yīng)的字段數(shù)據(jù),當(dāng)執(zhí)行到第七行時(shí),會(huì)生成類似如下的SQL語(yǔ)句:

  1. Select resume from user where id=’1’; 

這時(shí)會(huì)發(fā)起對(duì)resume字段數(shù)據(jù)真正的讀取操作

【編輯推薦】

  1. 講解NHibernate Session
  2. 簡(jiǎn)單描述Hibernate Sample
  3. Hibernate Annotations維護(hù)驗(yàn)證邏輯
  4. Hibernate ClassValidator實(shí)例
  5. 描述Hibernate持久性類
責(zé)任編輯:佚名 來(lái)源: InfoQ
相關(guān)推薦

2009-06-17 11:18:02

Hibernate延遲

2009-09-24 11:41:46

Hibernate延遲

2009-09-25 10:17:21

Hibernate延遲

2009-09-25 10:47:25

Hibernate延遲

2012-08-15 11:36:13

Hibernate

2021-05-08 09:49:07

JavaScript延遲加載

2009-09-28 09:40:28

Hibernate集合延遲加載

2009-09-24 09:25:10

Hibernate批量

2009-09-25 15:15:54

Hibernate檢索

2009-09-22 13:31:28

Hibernate C

2009-09-28 15:24:38

Hibernate V

2009-09-21 16:56:14

Hibernateibatis

2009-09-28 17:27:27

Hibernate A

2011-11-24 21:03:10

ibmdw

2009-07-02 09:39:37

Hibernate延遲

2009-09-28 09:35:10

Hibernate實(shí)現(xiàn)實(shí)體對(duì)象延遲加載

2009-09-22 17:55:51

Spring Hibe

2009-09-29 16:29:40

Hibernate查詢

2009-09-22 09:31:15

Hibernate主鍵

2009-09-27 14:33:01

Hibernate批量
點(diǎn)贊
收藏

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