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

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

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

    Hibernate進行時

    有關Hibenrate及其相關工具的主頁
    隨筆 - 0, 文章 - 16, 評論 - 29, 引用 - 0
    數據加載中……

    Hibernate3.2對sqlserver2005查詢分頁的處理

             對Hibernate的查詢分頁,想必大家都比較熟悉了。setFirstResult()和setMaxResults()就可以搞定。但是使用sqlserver的朋友發現了嗎,hibernate發送的分頁語句中總是會有令人心煩的"select top 數字" 這樣的字符串。比如你一頁顯示50條記錄,現在要查詢第100頁的數據,則會出現"select top 50000"這樣的語句,它是先把前5000條數據抓出到內存中,處理后僅返回最后的50條給你,但是其他的4500條不是多余的了嗎?想想還真是憋火。
             網上廣為流傳的一篇文章《實現Hibernate分頁查詢原理解讀》(作者robbin)中已經講的很清楚了,如果數據庫自身支持分頁查詢,那么這種數據庫的Dialect中的supportsLimit()方法將返回true,而Hibernate則才會去調用getLimitString()方法以得到分頁的語句,比如對mysql來說是
    pagingSelect.append(" limit ?, ?");
    而對于oracle是:
    pagingSelect.append("select * from ( select row_.*, rownum rownum_ from ( ");
    當然,sqlserver也不甘落后,好像非得supportsLimit它才舒服。它的supportsLimit()也是true,同時它的getLimitString()方法為:
    public String getLimitString(String querySelect, int offset, int limit) {
            
    if ( offset > 0 ) {
                
    throw new UnsupportedOperationException( "sql server has no offset" );
            }

            
    return new StringBuffer( querySelect.length()+8 )
                .append(querySelect)
                .insert( getAfterSelectInsertPoint(querySelect), 
    " top " + limit )
                .toString();
        }
    看到那個“top”的來歷了吧。
    而實事上,select top進行分頁查詢的效率非常之低,遠不如下面的語句:
    rs.absolute(firstRow);
    從《實現Hibernate分頁查詢原理解讀》中可以知道,rs.absolute(firstRow);執行的條件是數據庫Dialect不支持分頁查詢,這句話有點繞,其實它的真正意思是“supportsLimit()方法返回的是false”。當supportsLimit()返回false時,Hibernate采用rs.absolute(firstRow);來進行分頁查詢。說到這里,大家心知肚明了吧。其實解決起來比較簡單,你自己定義一個MySqlServer2005Dialect,繼承于原來的org.hibernate.dialect.SQLServerDialect,覆蓋其supportsLimit()方法,如下:
    public boolean supportsLimit() {
            
    return false;
        }
    然后在hibernate配置文件中使用你自己的MySqlServer2005Dialect方言即可。
    同時要注意的是,在Loader類的1471行有一個方法,它是:
    /**
         * Advance the cursor to the first required row of the <tt>ResultSet</tt>
         
    */

        
    private void advance(final ResultSet rs, final RowSelection selection)
                
    throws SQLException {

            
    final int firstRow = getFirstRow( selection );
            
    if ( firstRow != 0 ) {
                
    if ( getFactory().getSettings().isScrollableResultSetsEnabled() ) {
                    
    // we can go straight to the first required row
                    rs.absolute( firstRow );
                }

                
    else {
                    
    // we need to step through the rows one row at a time (slow)
                    for ( int m = 0; m < firstRow; m++ ) rs.next();
                }

            }

        }
    它和《實現Hibernate分頁查詢原理解讀》中描述的一樣,如果你的jdbc支持scrollable,那就調用rs.absolute(firstRow)定位到第一行,否則的話,就一行一行去移動吧。因此在配置文件中有一項很重要:
    <prop key="hibernate.jdbc.use_scrollable_resultset">true</prop>
    (注意我用的是spring的配置文件)上述這一行其實可以不寫,因為默認就是true了,但如果你顯示地把它寫上了,一定要設為true,如果為false的話,則記錄集rs會一行一行去移動,還是很費事的。

    posted on 2007-08-06 15:15 caixuetao 閱讀(3679) 評論(4)  編輯  收藏

    評論

    # re: Hibernate3.2對sqlserver2005查詢分頁的處理  回復  更多評論   

    這幾天正在看蔡老師的Hibernate那本書啊!覺得寫得很好!
    這篇文章我轉載到我blog上拉,不會介意吧!
    2007-08-08 20:48 | 咖啡迷

    # re: Hibernate3.2對sqlserver2005查詢分頁的處理  回復  更多評論   

    我試了下好像不行, 全部都取了
    2008-06-26 11:30 | agua

    # re: Hibernate3.2對sqlserver2005查詢分頁的處理[未登錄]  回復  更多評論   

    用最少1k~10w的數據量測試,結果說明,通過調用rs.absolute(firstRow)實現分頁,對于性能的提高并沒有幫助。
    2010-03-08 17:55 | C

    # re: Hibernate3.2對sqlserver2005查詢分頁的處理  回復  更多評論   

    我的也是不起作用!!!!!!! 任何方言配置了 都不起作用!
    2011-05-09 09:49 | 劉玉海

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲国产人成精品| 免费大黄网站在线观| 亚洲第一中文字幕| 国产精品偷伦视频免费观看了| 国产免费AV片无码永久免费| 亚洲成在人线aⅴ免费毛片 | 无码国产精品一区二区免费模式| 91麻豆精品国产自产在线观看亚洲| 深夜a级毛片免费视频| 国产成人精品久久亚洲| 美女网站在线观看视频免费的| 亚洲午夜激情视频| 永久在线观看免费视频| 91久久亚洲国产成人精品性色| 精品熟女少妇av免费久久| 亚洲人成网站在线播放影院在线| 亚洲免费在线观看视频| 亚洲一级片在线观看| 免费看a级黄色片| 特级毛片A级毛片免费播放| 亚洲中文字幕无码专区| 亚洲免费在线播放| 7777久久亚洲中文字幕| 免费大片在线观看网站| 丝袜捆绑调教视频免费区| 97久久精品亚洲中文字幕无码| 我们的2018在线观看免费高清| 无码亚洲成a人在线观看| 在线亚洲精品自拍| 久久午夜伦鲁片免费无码| 在线观看亚洲AV日韩AV| 亚洲午夜精品久久久久久浪潮| 美女内射无套日韩免费播放| 亚洲伊人久久大香线蕉结合| 免费很黄很色裸乳在线观看| 未满十八18禁止免费无码网站| 亚洲中文字幕无码mv| 国产亚洲A∨片在线观看| 四虎在线最新永久免费| 日韩精品视频在线观看免费| 久久亚洲精品成人av无码网站|