<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-67  評論-522  文章-0  trackbacks-0
        最早接觸Hibernate是在2004年,當(dāng)時懷著忐忑和不安的心情來學(xué)習(xí)這門技術(shù)。經(jīng)過這幾年的使用和研究,也積累了一定的經(jīng)驗(yàn),下面就HQLQBC查詢來談一下我從工作中得到的一些總結(jié)。
        本文不會講什么是Hibernate、什么是ORM、更不會談怎樣使用HQLQBC。本文的目的是讓大家對平常使用最多,也是最廣泛的與數(shù)據(jù)庫打交道的兩種方式,有一個新的認(rèn)識。
        恩,如果你還不知道Hibernate,大象建議你先去學(xué)一下再來看本文,如果你已經(jīng)是這方面的高手,大可以關(guān)掉瀏覽器,千萬不要因?yàn)楸救说挠抟姡屇銓Υ笙罂谡D筆伐,進(jìn)行人身攻擊。
        HQLQBC都是查詢檢索的方式,最開始,我一直使用的都是HQL,因?yàn)橐郧耙恢庇玫亩际?span lang="EN-US">SQL,覺得這東西和SQL差不多,上手很快。后來又用QBC,因?yàn)?span lang="EN-US">QBC
    是基于接口和類的對象化查詢,使代碼變得很清晰,很整潔。
        下面是查詢用戶表中,id2,年齡等于21,并且名字以J開頭的兩種查詢語句,它們的結(jié)果都是一樣,只是不同的表現(xiàn)方式。
        HQL:
        Query query = session
                .createQuery("from User u where u.id = 2 and u.age = 21 and u.name like 'J%'");

        List list = query.list();
        QBC
        Criteria criteria = session.createCriteria(User.class);
        List list = criteria.add(Expression.eq("id", 2)).add(
                Expression.eq("age", 21)).add(Expression.like("name", "J%"))
                .list();
        如果查詢再復(fù)雜一點(diǎn),需要關(guān)聯(lián)多張表,那上面這個HQL語句就會顯得很復(fù)雜,比較難以閱讀。對于QBC來說,需要再加一個createCriteria(),返回一個criteria新實(shí)例,比如說,用戶表與帳號表關(guān)聯(lián),需要根據(jù)帳號表中的帳號,開戶時間,金額等信息進(jìn)行查詢,可以寫成下面的形式:
    List list = criteria.add(Expression.eq("id"2)).add(
                    Expression.eq(
    "age"21)).add(Expression.like("name""J%"))
                    .createCriteria(
    "account", "a").add(
                            Expression.eq(
    "a.account_id"112546)).add(
                            Expression.eq(
    "a.start_date""2008-8-30")).add(
                            Expression.eq(
    "a.money_sum"1000)).list();
        account是用戶表中建的與帳號表的關(guān)聯(lián)對象屬性,a是別名。我為了便于說明,用的都是固定值,并且條件判斷也都是eq(等于),其實(shí)在實(shí)際開發(fā)中,這是不可能的,這些值全都會被變量所代替。add方法也不用寫在一起,可以分開來,特別是在查詢中,需要對傳入的參數(shù)進(jìn)行檢驗(yàn),這時就需要一個條件一個條件的往上加。
        這樣看來,好像QBCHQL要好一些,大象是這么認(rèn)為的:HQL簡單、靈活,QBC整潔、方便,不能說誰好誰不好,否則大名鼎鼎的Hibernate為什么要支持這兩種檢索方式呢?
        根據(jù)本人做開發(fā)的情況來看,在需要多表關(guān)聯(lián)查詢的時候,如果POJO類之間建立一對多或多對多這樣的關(guān)聯(lián)關(guān)系,效率是很低下的,就算你設(shè)置了延遲檢索,也會感覺很慢。而且在實(shí)際開發(fā)中,我還發(fā)現(xiàn),在數(shù)據(jù)庫中建立外鍵是一件非常吃力不討好的事情,因?yàn)楹芏鄷r候出錯都是跟外鍵有關(guān)系,主要體現(xiàn)在修改和刪除。而POJO之間建立對象關(guān)系,則會增加編碼的復(fù)雜程度,提高出錯機(jī)率,另外還會增加用戶等待的時間。這是大象以前開發(fā)時所經(jīng)歷過的,所以后來的項(xiàng)目中,對于數(shù)據(jù)庫中的每個表,只給一個流水號主鍵,不在建立其它的外鍵關(guān)系,而在POJO中,只設(shè)定最原始的屬性與表中的字段對應(yīng),對于需要做多表查詢的情況,建立視圖,把需要查詢的字段屬性與要在列表中顯示的字段屬性都放在視圖POJO中,這樣,不管是HQL還是QBC,一個類就可以解決問題,而且對視圖查詢可比使用表之間的關(guān)聯(lián)關(guān)系查詢要快很多。
        在項(xiàng)目中,到底采取哪種檢索方式,關(guān)鍵還得看項(xiàng)目負(fù)責(zé)人。比如大象現(xiàn)在做的這個項(xiàng)目就規(guī)定了,必須使用QBC,而且除報表外,不準(zhǔn)使用視圖。呵呵,這樣的情況,只能在POJO之間建立關(guān)聯(lián)關(guān)系了,不過能少建,我們還是會盡量的減少類之間的關(guān)聯(lián),好在現(xiàn)在開發(fā)用的JDK5.0的,因此我們可以使用注解的方式定義一些臨時對象屬性,這樣也省掉了以前必須得寫的hbm.xml文件,有時也采用仿視圖的方式用JavaBean來封裝一些對象和屬性。
        大家看到這里,有什么想法呢?歡迎大家提出自己寶貴的意見,我們一起來學(xué)習(xí)和研究,共同分享成功的經(jīng)驗(yàn)。
        本文為菠蘿大象原創(chuàng),如要轉(zhuǎn)載請注明出處。


    posted on 2008-08-30 22:29 菠蘿大象 閱讀(4269) 評論(2)  編輯  收藏 所屬分類: Hibernate

    評論:
    # re: 小談Hibernate中的HQL與QBC查詢 2008-08-31 08:13 | johnhan2008
    對大數(shù)據(jù)量來說,hibernate關(guān)聯(lián)查詢速度上的差異確實(shí)很明顯。不過hibernate也支持原生SQL,對那些查詢速度要求比較高的,我們就可以用原生SQL呀。你說的視圖,我也是比較支持的。  回復(fù)  更多評論
      
    # re: 小談Hibernate中的HQL與QBC查詢 2008-08-31 21:06 | 菠蘿大象
    @johnhan2008
    你說的很對,Hibernate是支持SQL方式檢索的,之所以我不談這個,是因?yàn)槲覀兪褂肏ibernate,就是為了面向?qū)ο螅挥迷偃ッ鎸able。在數(shù)據(jù)庫中調(diào)試好視圖,用它來幫助查詢,可以免去再寫繁瑣的SQL語句,另外,在代碼中寫入SQL語句對以后的修改和維護(hù)會帶來一些不便之處。不過還是那句話,關(guān)鍵看項(xiàng)目負(fù)責(zé)人采取什么方式。呵呵~~~  回復(fù)  更多評論
      

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 在线观看免费av网站| 精品亚洲国产成AV人片传媒| 99视频全部免费精品全部四虎| 美女视频黄视大全视频免费的| 亚洲av永久无码精品三区在线4 | 亚洲高清无在码在线无弹窗 | 亚洲av日韩av永久在线观看| 亚洲黄网在线观看| 亚洲gv猛男gv无码男同短文| 亚洲成a人片在线观看国产| 女人被弄到高潮的免费视频| 亚洲一区二区三区免费视频| 久久狠狠躁免费观看2020| 国产精品九九久久免费视频| 狠狠热精品免费观看| 亚洲AV无码AV日韩AV网站| 亚洲欧美日韩国产成人| 久久国产亚洲精品| 亚洲午夜久久久精品电影院| 老色鬼久久亚洲AV综合| 久久久久亚洲精品影视| 亚洲国产综合无码一区| 亚洲熟妇av一区二区三区| 中文字幕亚洲乱码熟女一区二区 | 亚洲国产精品久久久久秋霞小| 亚洲最大福利视频| 亚洲娇小性色xxxx| 中文文字幕文字幕亚洲色| 亚洲国产人成在线观看| 亚洲国产成人久久77| 亚洲一级毛片中文字幕| 亚洲人xxx日本人18| 激情内射亚洲一区二区三区爱妻| 亚洲人成7777影视在线观看| 亚洲综合中文字幕无线码| 国产精品亚洲综合久久 | 免费观看毛片视频| 日本免费网站在线观看| 四虎1515hm免费国产| 亚洲国产精品自产在线播放 | 青青操免费在线视频|