国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
ibatis中queryForPaginatedList分頁(yè) 源碼分析
在ibatis中有一個(gè)很吸引人的方法,queryForPaginatedList(java.lang.String id, int pageSize),可以返回 PaginatedList的對(duì)象,
實(shí)現(xiàn)翻頁(yè),剛才測(cè)試了一下PaginatedList,在1-2w行數(shù)據(jù)的時(shí)候還可以工作,但是在一個(gè)30w行的表里翻頁(yè),一次select用了363.031second
忍不住看了一下源,發(fā)現(xiàn)ibatis的分頁(yè)依賴于數(shù)據(jù)庫(kù)的jdbcDriver.

調(diào)用次序如下SqlMapClientImpl.queryForPaginatedList->SqlMapSessionImpl.queryForPaginatedList
->SqlMapExecutorDelegate.queryForPaginatedList->GeneralStatement.executeQueryForList
->GeneralStatment.executeQueryWithCallback->GeneralStatment.executeQueryWithCallback
->SqlExecutor.executeQuery->SqlExecutor.handleMultipleResults()
分頁(yè)處理的函數(shù)如下
Java代碼
  1. private void handleResults(RequestScope request, ResultSet rs, int skipResults, int maxResults, RowHandlerCallback callback) throws SQLException {   
  2.   
  3.     try {   
  4.   
  5.       request.setResultSet(rs);   
  6.   
  7.       ResultMap resultMap = request.getResultMap();   
  8.   
  9.       if (resultMap != null) {   
  10.   
  11.         // Skip Results   
  12.   
  13.         if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {   
  14.   
  15.           if (skipResults > 0) {   
  16.   
  17.             rs.absolute(skipResults);   
  18.   
  19.           }   
  20.   
  21.         } else {   
  22.   
  23.           for (int i = 0; i < skipResults; i++) {   
  24.   
  25.             if (!rs.next()) {   
  26.   
  27.               return;   
  28.   
  29.             }   
  30.   
  31.           }   
  32.   
  33.         }   
  34.   
  35. // Get Results   
  36. int resultsFetched = 0;   
  37. while ((maxResults == SqlExecutor.NO_MAXIMUM_RESULTS || resultsFetched < maxResults) && rs.next()) {   
  38. Object[] columnValues = resultMap.resolveSubMap(request, rs).getResults(request, rs);   
  39. callback.handleResultObject(request, columnValues, rs);   
  40. resultsFetched++;   
  41. }   
  42. }   
  43. finally {   
  44. request.setResultSet(null);   
  45. }   
  46. }   

返回的PaginatedList實(shí)際上是PaginatedDataList類的對(duì)象,每次翻頁(yè)的時(shí)候最后都會(huì)調(diào)用
Java代碼
  1. private List getList(int idx, int localPageSize) throws SQLException {   
  2.   
  3.     return sqlMapExecutor.queryForList(statementName, parameterObject, (idx) * pageSize, localPageSize);   
  4.   
  5.   }  

這個(gè)方法,可見(jiàn)ibatis的分頁(yè)機(jī)制要看jdbcDriver如何實(shí)現(xiàn)以及是否支持rs.absolute(skipResults)。
這種實(shí)現(xiàn)肯定不如數(shù)據(jù)庫(kù)自己支持的分頁(yè)方式來(lái)的快,一旦碰到數(shù)據(jù)量大的表,馬上會(huì)死翹翹。
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
使ibatis支持hibernate式的物理分頁(yè)
關(guān)于ibatis中queryForPaginatedList方法的分析
iBatis2-SqlMap的配置總結(jié)
MyBatis:簡(jiǎn)單物理分頁(yè)實(shí)現(xiàn)(Plugin)
MyBatis基礎(chǔ)面試題及答案
SSM框架——實(shí)現(xiàn)分頁(yè)和搜索分頁(yè)
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服