http://www.iteye.com/topic/136712

详细demo:参照http://www.kusoft.net

我的数据库是采用mssql2000 
采用分页必定数据量比较大: 
按照ibatis的自带的是缓存分页.如果一大的肯定内存吃不消. 但是可以采用queryForList,却得不到总记录数码相. 
要得到总记录数,因此我采用物理游标进行分页. 
功能:需要得到结果的记录数,显示每页几行

(1)定义一个接口Pager:

  1. public interface Pager {
  2. //总共几行
  3. public int getRows();
  4. //存入一页的数据
  5. public List<Object> getList();
  6. public void setList(List<Object> list);
  7. public void setRows(int rows);
  8. }

(2)Pager实现类PagerImpl

  1. public class PagerImpl implements Pager {
  2. private List<Object> list = null;
  3. private int rows = 0;
  4. public List<Object> getList() {
  5. return list;
  6. }
  7. public void setList(List<Object> list) {
  8. this.list = list;
  9. }
  10. public int getRows() {
  11. return rows;
  12. }
  13. public void setRows(int rows) {
  14. this.rows = rows;
  15. }
  16. }

(3)扩展ibatis自带接口 SqlMapExecutor

  1. //skip 起启行,max每页几行
  2. Pager queryForPager(String id, Object parameterObject, int skip, int max) throws SQLException;
  3. Pager queryForPager(String id, Object parameterObject, int skip) throws SQLException;
  4. //根据条件查出所有结果
  5. Pager queryForPager(String id, Object parameterObject) throws SQLException;

(4)扩展ibatis接口 SqlMapExecutor的实现类有两个SqlMapClientImpl,SqlMapSessionImpl

  1. SqlMapClientImpl的扩展如下
  2. public Pager queryForPager(String id, Object paramObject, int skip, int max)
  3. throws SQLException {
  4. if (max <= 0)
  5. return getLocalSqlMapSession().queryForPager(id, paramObject, skip);
  6. else
  7. return getLocalSqlMapSession().queryForPager(id, paramObject, skip,
  8. max);
  9. }
  10. public Pager queryForPager(String id, Object parameterObject, int skip)
  11. throws SQLException {
  12. return getLocalSqlMapSession().queryForPager(id, parameterObject, skip,
  13. SqlExecutor.NO_MAXIMUM_RESULTS);
  14. }
  15. public Pager queryForPager(String id, Object parameterObject)
  16. throws SQLException {
  17. return getLocalSqlMapSession().queryForPager(id, parameterObject,
  18. SqlExecutor.NO_SKIPPED_RESULTS, SqlExecutor.NO_MAXIMUM_RESULTS);
  19. }

(5)最终修改SqlExecutor获取总记录数 
SqlExecutor:439行

  1. if (resultMap != null) {
  2. // Skip Results
  3. if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {
  4. rs.beforeFirst();
  5. if (skipResults > 0) {
  6. rs.absolute(skipResults);
  7. }
  8. } else {
  9. for (int i = 0; i < skipResults; i++) {
  10. if (!rs.next()) {
  11. return;
  12. }
  13. }
  14. }
  15. // Get Results
  16. int resultsFetched = 0;
  17. while ((maxResults == SqlExecutor.NO_MAXIMUM_RESULTS || resultsFetched < maxResults)
  18. && rs.next()) {
  19. Object[] columnValues = resultMap
  20. .resolveSubMap(request, rs).getResults(request, rs);
  21. callback.handleResultObject(request, columnValues, rs);
  22. resultsFetched++;
  23. }
  24. if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {
  25. rs.last();
  26. request.setRows(rs.getRow());
  27. } else {
  28. int total = skipResults + resultsFetched;
  29. while(rs.next()){
  30. total++;
  31. }
  32. request.setRows(total);
  33. }
  34. }

这样就可以了

(6)如何调用 
6.1创建一个方法

  1. public static Pager pager(GroupVO vo,int offset,int limit)throws SQLException{
  2. return sqlMapper.queryForPager("list",vo,offset);
  3. }
  1. public static void main(String[] args){
  2. try {
  3. SimpleExample se = new SimpleExample();
  4. GroupVO vo = new GroupVO();
  5. Pager pager = se.pager(vo,0,10);
  6. //vo.setGroup_no("100");
  7. //vo.setGroup_name("fengjian");
  8. //vo.setGroup_desc("thanks");
  9. System.out.println("totalsize = "+pager.getRows());
  10. List list = pager.getList();
  11. if(list!=null)
  12. for(int i=0; i<list.size(); i++){
  13. GroupVO v = (GroupVO)list.get(i);
  14. System.out.println("group no = " + v.getGroup_no());
  15. }
  16. } catch (SQLException e) {
  17. e.printStackTrace();
  18. }
  19. }

有什么不同看法:msn:linuxfjy@hotmail.com, mail: kusoft@qq.com

关于ibatis进行物理游标分页的更多相关文章

  1. DRF框架(九)——drf偏移分页组件、drf游标分页组件(了解)、自定义过滤器、过滤器插件django-filter

    drf偏移分页组件 paginations.py from rest_framework.pagination import LimitOffsetPagination class MyLimitOf ...

  2. DRF url控制 解析器 响应器 版本控制 分页(常规分页,偏移分页,cursor游标分页)

    url控制 第二种写法(只要继承了ViewSetMixin) url(r'^pub/$',views.Pub.as_view({'get':'list','post':'create'})), #获取 ...

  3. drf偏移分页组件-游标分页-自定义过滤器-过滤器插件django-filter

    drf偏移分页组件 LimitOffsetPagination 源码分析:获取参数 pahenations.py from rest_framework.pagination import Limit ...

  4. ibatis 实现 物理级别的 分页 兼容多种数据库(转载)

    最近在看iBatis时,想做用动态Sql做个分布.因为在做项目时用iBator工具生成没有分页的功能,只有一些我们常用的功能.所以要对生成后的代码做修改.我在Java高手真经的一书中看到有做了MySq ...

  5. oracle ibatis 存储过程 返回游标 嵌套表

    自己解决问题了 问题总结: 1.index by表不能存储在数据库中的type中,故选择嵌套表. 2.ibatis不支持oracle的复合数据类型的返回.(个人理解) 3.替代方案:用返回oracle ...

  6. solr研磨之游标分页

    普通分页 当需要深度分页的时候,比如查询第10000页数据,每页显示10条,意味着需要提取前10000 x 10 页的数据,并将这100000条数据缓存在内存中,然后在内存中进行排序.最后返回最后10 ...

  7. Ibatis调用存储过程实现增删改以及分页查询

    1.Ibatis实现增删改操作很简单了,通常我是将某一模块的增删改功能写在一个存储过程里,通过一个标识符去区分执行增加还是修改抑或删除操作. statement: <!-- 存储过程:实现学生的 ...

  8. IBatis的分页研究

    IBatis的分页研究 博客分类: Ibatis学习   摘自: http://cpu.iteye.com/blog/311395 yangtingkun   Oracle分页查询语句 ibaits. ...

  9. ASP.NET和MSSQL高性能分页

    首先是存储过程,只取出我需要的那段数据,如果页数超过数据总数,自动返回最后一页的纪录: set ANSI_NULLS ON set QUOTED_IDENTIFIER ON GO -- ======= ...

随机推荐

  1. Problem - 433C - Codeforces解题报告

    对于这题本人刚开始的时候的想法是:先把最大两数差的位置找到然后merge计算一个值再与一连串相同的数做merge后计算一个值比较取最大值输出:可提交后发现不对,于是本人就搜了一下正解发现原来这题的正确 ...

  2. javaweb 之javascript 结合

    1.javascript的简介 * 是基于对象和事件驱动的语言,应用与客户端. - 基于对象: ** 提供好了很多对象,可以直接拿过来使用 - 事件驱动: ** html做网站静态效果,javascr ...

  3. 在iOS的XCode工程配置中为什么要用-all_load&-ObjC

    -ObjC 这个flag告诉链接器把库中定义的Objective-C类和Category都加载进来.这样编译之后的app会变大(因为加载了其他的objc代码进来).但是如果静态库中有类和categor ...

  4. 简单实例一步一步帮你搞清楚MVC3中的路由以及区域

    我们都知道MVC 3 程序的所有请求都是先经过路由解析然后分配到特定的Controller 以及 Action 中的,为什么这些知识讲完了Controller Action Model 后再讲呢?这个 ...

  5. Tsinsen A1516. fx 数位dp

    题目: http://www.tsinsen.com/A1516 A1516. fx 时间限制:2.0s   内存限制:256.0MB    总提交次数:164   AC次数:72   平均分:51. ...

  6. Xmind Pro 3.4.0.201311050558 Xmind 3.4 破解版 Crack

    其实就一个附件.某大神那里的下不到了.从这里就好了. 使用方法请参见压缩包~ 如果连接不能用了请及时告知回复.>< 仅适用于与版本号为201311050558的Xmind.当然尊重正版开发 ...

  7. Scala学习笔记(一)数据类型

    .类型参数化数组 val arrayString = Array[String](2); arrayString (0)="Hello"; arrayString (1)=&quo ...

  8. Codeforces149D - Coloring Brackets(区间DP)

    题目大意 要求你对一个合法的括号序列进行染色,并且需要满足以下条件 1.要么不染色,要么染红色或者蓝色 2.对于任何一对括号,他们当中有且仅有一个被染色 3.相邻的括号不能染相同的颜色 题解 用区间d ...

  9. DevExpress控件XtraGrid的Master-Detail中DetailViewCaption显示问题

    今天遇到XtraGrid身档抬头显示不对问题,查找了很多资料后未找到解决办法,后浏览至此文作者发现解决问题的方法就是:DataSet中的RelactionName跟DetailGridview的Lea ...

  10. 【三支火把】---一份程序看懂C程序printf()的几种常用用法

    闲来继续巩固我的学习之路,今天略微整理了一下,C程序中Printf()的一些常用用法,虽然自己以前好像会,但是不够系统,今天大致整理了一些,先贴上来看看,以后在看到其他,继续补充,希望能帮到一些像我一 ...