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

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

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
概括Hibernate屬性延遲加載

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

創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的江津網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

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

Hibernate屬性延遲加載

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

 
 
 
  1.  name=”com.neusoft.entity.User” table=”user”
  2. ……
  3.  name=”resume”type=”java.sql.Clob”column=”resume” lazy=’true’/>

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

 
 
 
  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();i++){
  5. User user=(User)list.get(i);
  6. System.out.println(user.getName());
  7. System.out.println(user.getResume());
  8. }

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

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

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

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

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


網(wǎng)站名稱:概括Hibernate屬性延遲加載
文章出自:http://www.5511xx.com/article/dpodsid.html