iBATIS分页的一些理解
创始人
2024-04-18 12:40:36
0

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

忍不住看了一下源,发现iBATIS的分页依赖于数据库的jdbcDriver.

调用次序如下

  1. SqlMapClientImpl.queryForPaginatedList  
  2. ->SqlMapSessionImpl.queryForPaginatedList   
  3. ->SqlMapExecutorDelegate.queryForPaginatedList  
  4. ->GeneralStatement.executeQueryForList   
  5. ->GeneralStatment.executeQueryWithCallback  
  6. ->GeneralStatment.executeQueryWithCallback   
  7. ->SqlExecutor.executeQuery  
  8. ->SqlExecutor.handleMultipleResults()  

iBATIS分页处理的函数如下

Java代码

  1. private void handleResults(RequestScope request, ResultSet rs, int skipResults, int maxResults, RowHandlerCallback callback); throws SQLException {     
  2.     try {     
  3.       request.setResultSet(rs);;     
  4.       ResultMap resultMap = request.getResultMap();;     
  5.       if (resultMap != null); {     
  6.         // Skip Results     
  7.         if (rs.getType(); != ResultSet.TYPE_FORWARD_ONLY); {     
  8.           if (skipResults > 0); {     
  9.             rs.absolute(skipResults);;     
  10.           }     
  11.         } else {     
  12.           for (int i = 0; i < skipResults; i++); {     
  13.             if (!rs.next();); {     
  14.               return;     
  15.             }     
  16.           }     
  17.         }     
  18.     
  19.         // Get Results     
  20.         int resultsFetched = 0;     
  21.         while ((maxResults == SqlExecutor.NO_MAXIMUM_RESULTS || resultsFetched < maxResults); && rs.next();); {     
  22.           Object[] columnValues = resultMap.resolveSubMap(request, rs);.getResults(request, rs);;     
  23.           callback.handleResultObject(request, columnValues, rs);;     
  24.           resultsFetched++;     
  25.         }     
  26.       }     
  27.     } finally {     
  28.       request.setResultSet(null);;     
  29.     }     
  30.   }   

返回的PaginatedList实际上是PaginatedDataList类的对象,每次翻页的时候最后都会调用

Java代码

  1. private List getList(int idx, int localPageSize); throws SQLException {     
  2.    return sqlMapExecutor.queryForList(statementName, parameterObject, (idx); * pageSize, localPageSize);;     
  3.  } 

这个方法,可见iBATIS的分页机制要看jdbcDriver如何实现以及是否支持rs.absolute(skipResults)。

iBATIS分页的情况就介绍到这里,希望对你有所帮助。

【编辑推荐】

  1. Struts2.0+ibatis2.3整合实例实现服务层及 Struts
  2. Struts2.0+ibatis2.3整合实例实现UI层浅析
  3. iBATIS入门程序六大步详解
  4. iBATIS DAO事务浅析
  5. iBATIS使用$和#的一些理解

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...