iBatis分页源代码解析

在ibatis中有一个很吸引人的方法,queryForPaginatedList(java.lang.String id, int pageSize),可以返回 PaginatedList的对象,实现翻页,刚才测试了一下PaginatedList,在1-2w行数据的时候还可以工作,但是在一个30w行的表里翻页,一次select用了363.031second .忍不住看了一下源,发现ibatis的分页依赖于数据库的jdbcDriver.

调用次序如下
SqlMapClientImpl.queryForPaginatedList->SqlMapSessionImpl.queryForPaginatedList->SqlMapExecutorDelegate.queryForPaginatedList->GeneralStatement.executeQueryForList->GeneralStatment.executeQueryWithCallback->GeneralStatment.executeQueryWithCallback->SqlExecutor.executeQuery->SqlExecutor.handleMultipleResults()
分页处理的函数如下

private   void  handleResults(RequestScope request, ResultSet rs,  int  skipResults,  int  maxResults, RowHandlerCallback callback)  throws  SQLException  {
    
try {
      request.setResultSet(rs);
      ResultMap resultMap 
= request.getResultMap();
      
if (resultMap != null{
        
// Skip Results
        if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {
          
if (skipResults > 0
            rs.absolute(skipResults);
          }

        }
 else {
          
for (int i = 0; i < skipResults; i++{
            
if (!rs.next()) {
              
return;
            }

          }

        }
 

        
// Get Results
        int resultsFetched = 0;
        
while ((maxResults == SqlExecutor.NO_MAXIMUM_RESULTS || resultsFetched < maxResults) && rs.next()) {
          Object[] columnValues 
= resultMap.resolveSubMap(request, rs).getResults(request, rs);
          callback.handleResultObject(request, columnValues, rs);
          resultsFetched
++;
        }

      }

    }
 finally {
      request.setResultSet(
null);
    }

  }
 返回的PaginatedList实际上是PaginatedDataList类的对象,每次翻页的时候最后都会调用
  private  List getList( int  idx,  int  localPageSize)  throws  SQLException 
    
return sqlMapExecutor.queryForList(statementName, parameterObject, (idx) * pageSize, localPageSize);
  }
这个方法,可见ibatis的分页机制要看jdbcDriver如何实现以及是否支持rs.absolute(skipResults)。
这种实现肯定不如数据库自己支持的分页方式来的快,一旦碰到数据量大的表,马上会死翘翘。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值