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

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

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

    隨筆 - 4  文章 - 10  trackbacks - 0
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(1)

    隨筆檔案

    文章分類

    文章檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    1、針對oracle數據庫而言,Fetch Size 是設定JDBC的Statement讀取數據的時候每次從數據庫中取出的記錄條數,一般設置為30、50、100。Oracle數據庫的JDBC驅動默認的Fetch Size=15,設置Fetch Size設置為:30、50,性能會有明顯提升,如果繼續增大,超出100,性能提升不明顯,反而會消耗內存。
        即在hibernate配制文件中進行配制:
     
     1 <property name="hibernateProperties">
     2             <props>
     3                 <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
     4                 <prop key="hibernate.show_sql">false</prop>
     5                 <!-- Create/update the database tables automatically when the JVM starts up
     6                     <prop key="hibernate.hbm2ddl.auto">update</prop> -->
     7                 <!-- Turn batching off for better error messages under PostgreSQL 
     8                     <prop key="hibernate.jdbc.batch_size">100</prop> -->
     9                 <prop key="hibernate.jdbc.batch_size">50</prop>
    10             </props>
    11         </property>
    Fetch Size設的越大,讀數據庫的次數越少,速度越快;Fetch Size越小,讀數據庫的次數越多,速度越慢。
    2、如果是超大的系統,建議生成htm文件。加快頁面提升速度。
    3、不要把所有的責任推在hibernate上,對代碼進行重構,減少對數據庫的操作,盡量避免在數據庫查詢時使用in操作,以及避免遞歸查詢操作,代碼質量、系統設計的合理性決定系統性能的高低。
    4、 對大數據量查詢時,慎用list()或者iterator()返回查詢結果,
         (1). 使用List()返回結果時,Hibernate會所有查詢結果初始化為持久化對象,結果集較大時,會占用很多的處理時間。
         (2). 而使用iterator()返回結果時,在每次調用iterator.next()返回對象并使用對象時,Hibernate才調用查詢將對應的對象初始化,對于大數據量時,每調用一次查詢都會花費較多的時間。當結果集較大,但是含有較大量相同的數據,或者結果集不是全部都會使用時,使用iterator()才有優勢。
    5、在一對多、多對一的關系中,使用延遲加載機制,會使不少的對象在使用時方會初始化,這樣可使得節省內存空間以及減少數據庫的負荷,而且若PO中的集合沒有被使用時,就可減少互數據庫的交互從而減少處理時間。
    6、對含有關聯的PO(持久化對象)時,若default-cascade="all"或者 “save-update”,新增PO時,請注意對PO中的集合的賦值操作,因為有可能使得多執行一次update操作。 
    7、 對于大數據量新增、修改、刪除操作或者是對大數據量的查詢,與數據庫的交互次數是決定處理時間的最重要因素,減少交互的次數是提升效率的最好途徑,所以在開發過程中,請將show_sql設置為true,深入了解Hibernate的處理過程,嘗試不同的方式,可以使得效率提升。盡可能對每個頁面的顯示,對數據庫的操作減少到100----150條以內。越少越好。
    以上是在進行struts+hibernate+spring進行項目開發中,對hibernate性能優化的幾點心得。
    posted on 2007-08-17 15:41 冬天出走的豬 閱讀(167) 評論(0)  編輯  收藏 所屬分類: hibernate
    主站蜘蛛池模板: 久久精品成人免费观看97| 国产福利免费观看| 精品国产免费一区二区三区香蕉| 两个人日本免费完整版在线观看1| 未满十八18禁止免费无码网站 | 亚洲国产成人久久精品动漫| 亚洲一区精品无码| 亚洲不卡中文字幕无码| 亚洲日本香蕉视频观看视频| 亚洲人成网站18禁止| 亚洲精品视频免费| 中文字幕无码视频手机免费看| 国产一区视频在线免费观看| 亚洲国产成人久久综合碰碰动漫3d | 98精品全国免费观看视频| 国产jizzjizz视频免费看| 亚洲av无码专区在线电影| 最近更新免费中文字幕大全| 热99re久久免费视精品频软件| 中文亚洲AV片不卡在线观看 | 24小时免费直播在线观看| 亚洲国产精品视频| 亚洲午夜在线一区| A毛片毛片看免费| 亚洲AV无码一区东京热久久 | 国产亚洲福利精品一区| 粉色视频免费入口| 亚洲黄色片免费看| 亚洲精品久久久www| 2020久久精品亚洲热综合一本| xxxxxx日本处大片免费看| 大地资源二在线观看免费高清| 亚洲色无码专区一区| 在线观看成人免费视频不卡| 亚洲熟女少妇一区二区| 久久综合给合久久国产免费| 亚洲人成综合网站7777香蕉| 成人在线免费看片| 美女被暴羞羞免费视频| 免费国产在线观看老王影院| 亚洲狠狠婷婷综合久久|