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

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

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

    當Hibernate遭遇多個結構相同的表

    Posted on 2008-03-19 23:58 Norvid 閱讀(1760) 評論(0)  編輯  收藏 所屬分類: 點點滴滴
    在一些大數據量的應用中,通常會將一些數據量大的表分成多個。最簡單的情況是設置一個實時表,用來保存最近一段時間的數據,我們叫它recent_data;同時又有一個保存歷史數據的表,名叫history_data。當然,也可以采用一段時間一個表的方式,如一個月一張表:data_200803。

    recent_data保存最新的數據,通常是為了提供預覽、監視等對顯示速度要求高的功能,使用者此時往往是想要一個數據的大概印象,因此響應速度十分重要;而history_data則面向詳細查詢,這時使用者關注的數據,因此,慢是可以接受的。

    介紹背景介紹得有點跑題了,還是回來說說正題。面對recent_data和history_data這兩張表要使用hibernate進行封裝時,該怎么解決呢?

    這里有三個方法。

    1. 使用古老而笨拙的方法——為每個table建立一個class,如RecentData和HistoryData。然后在上層程序中使用這兩個類。
    優點:簡單,方便,快捷,還不費腦子!(僅對負責Hibernate封裝的人來說……)
    缺點:上層使用極其復雜,明明就是同一個東西,偏偏弄成兩個對象,要寫兩套實現……&@&*¥#%

    2. 建立一個基類Data,然后派生出RecentData和HistoryData,分別映射兩個表。派生出的兩個類不用寫什么東西,僅僅是extends了Data就行了。對外一致以基類Data出現,這樣上層使用時,就可以統一用Data類了。此法為第一種方法的改進版,也是我偏愛的解決方法。
    優點:Hibernate映射簡單,上層使用也簡單
    缺點:多了兩個類,盡管里面啥也沒有

    3. 使用Hibernate3新增加的entity-name特性,用一個類來映射多個table。這里有一個詳細的例子(http://www.javaworld.com.tw/confluence/pages/viewpage.action?pageId=3150)。
    優點:不用定義那么多類,映射也挺簡單
    缺點:Hibernate3才有此功能(如果你還在用之前的版本的話……)

    -- EOF --



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


    網站導航:
     

    posts - 0, comments - 9, trackbacks - 0, articles - 13

    Copyright © Norvid

    主站蜘蛛池模板: 亚洲国产另类久久久精品| 国产免费av片在线播放| 亚洲av无码国产精品色午夜字幕| 深夜a级毛片免费无码| 免费人成网站在线播放| 亚洲一本一道一区二区三区| 免费观看成人毛片a片2008| 亚洲AV无码专区在线亚| 搡女人真爽免费视频大全| 久久久久免费看黄A片APP| 亚洲白色白色永久观看| 四虎1515hh永久久免费| 亚洲一区中文字幕在线电影网| 日本免费xxxx色视频| 中文字幕乱码亚洲无线三区| 男女拍拍拍免费视频网站| 色www永久免费视频| 亚洲短视频男人的影院| 特级毛片爽www免费版| 最新仑乱免费视频| 亚洲大尺度无码无码专线一区| 最近中文字幕mv免费高清在线 | 免费a级毛片网站| 一级毛片免费播放试看60分钟| 亚洲欧洲∨国产一区二区三区| 国产成人一区二区三区视频免费| 亚洲理论在线观看| 日本19禁啪啪无遮挡免费动图| 亚洲国产综合在线| 免费被黄网站在观看| 暖暖免费中文在线日本| 久久91亚洲人成电影网站| 中文字幕免费在线| 337p日本欧洲亚洲大胆人人| 色妞WWW精品免费视频| 污视频网站在线观看免费| 亚洲国产精品久久| 日韩免费一区二区三区| 中国一级毛片免费看视频| 亚洲乱码一区av春药高潮| 久草视频免费在线观看|