关于ibatis进行物理游标分页
http://www.iteye.com/topic/136712
详细demo:参照http://www.kusoft.net
我的数据库是采用mssql2000
采用分页必定数据量比较大:
按照ibatis的自带的是缓存分页.如果一大的肯定内存吃不消. 但是可以采用queryForList,却得不到总记录数码相.
要得到总记录数,因此我采用物理游标进行分页.
功能:需要得到结果的记录数,显示每页几行
(1)定义一个接口Pager:
- public interface Pager {
- //总共几行
- public int getRows();
- //存入一页的数据
- public List<Object> getList();
- public void setList(List<Object> list);
- public void setRows(int rows);
- }
(2)Pager实现类PagerImpl
- public class PagerImpl implements Pager {
- private List<Object> list = null;
- private int rows = 0;
- public List<Object> getList() {
- return list;
- }
- public void setList(List<Object> list) {
- this.list = list;
- }
- public int getRows() {
- return rows;
- }
- public void setRows(int rows) {
- this.rows = rows;
- }
- }
(3)扩展ibatis自带接口 SqlMapExecutor
- //skip 起启行,max每页几行
- Pager queryForPager(String id, Object parameterObject, int skip, int max) throws SQLException;
- Pager queryForPager(String id, Object parameterObject, int skip) throws SQLException;
- //根据条件查出所有结果
- Pager queryForPager(String id, Object parameterObject) throws SQLException;
(4)扩展ibatis接口 SqlMapExecutor的实现类有两个SqlMapClientImpl,SqlMapSessionImpl
- SqlMapClientImpl的扩展如下
- public Pager queryForPager(String id, Object paramObject, int skip, int max)
- throws SQLException {
- if (max <= 0)
- return getLocalSqlMapSession().queryForPager(id, paramObject, skip);
- else
- return getLocalSqlMapSession().queryForPager(id, paramObject, skip,
- max);
- }
- public Pager queryForPager(String id, Object parameterObject, int skip)
- throws SQLException {
- return getLocalSqlMapSession().queryForPager(id, parameterObject, skip,
- SqlExecutor.NO_MAXIMUM_RESULTS);
- }
- public Pager queryForPager(String id, Object parameterObject)
- throws SQLException {
- return getLocalSqlMapSession().queryForPager(id, parameterObject,
- SqlExecutor.NO_SKIPPED_RESULTS, SqlExecutor.NO_MAXIMUM_RESULTS);
- }
(5)最终修改SqlExecutor获取总记录数
SqlExecutor:439行
- if (resultMap != null) {
- // Skip Results
- if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {
- rs.beforeFirst();
- 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++;
- }
- if (rs.getType() != ResultSet.TYPE_FORWARD_ONLY) {
- rs.last();
- request.setRows(rs.getRow());
- } else {
- int total = skipResults + resultsFetched;
- while(rs.next()){
- total++;
- }
- request.setRows(total);
- }
- }
这样就可以了
(6)如何调用
6.1创建一个方法
- public static Pager pager(GroupVO vo,int offset,int limit)throws SQLException{
- return sqlMapper.queryForPager("list",vo,offset);
- }
- public static void main(String[] args){
- try {
- SimpleExample se = new SimpleExample();
- GroupVO vo = new GroupVO();
- Pager pager = se.pager(vo,0,10);
- //vo.setGroup_no("100");
- //vo.setGroup_name("fengjian");
- //vo.setGroup_desc("thanks");
- System.out.println("totalsize = "+pager.getRows());
- List list = pager.getList();
- if(list!=null)
- for(int i=0; i<list.size(); i++){
- GroupVO v = (GroupVO)list.get(i);
- System.out.println("group no = " + v.getGroup_no());
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }
- }
有什么不同看法:msn:linuxfjy@hotmail.com, mail: kusoft@qq.com
关于ibatis进行物理游标分页的更多相关文章
- DRF框架(九)——drf偏移分页组件、drf游标分页组件(了解)、自定义过滤器、过滤器插件django-filter
drf偏移分页组件 paginations.py from rest_framework.pagination import LimitOffsetPagination class MyLimitOf ...
- DRF url控制 解析器 响应器 版本控制 分页(常规分页,偏移分页,cursor游标分页)
url控制 第二种写法(只要继承了ViewSetMixin) url(r'^pub/$',views.Pub.as_view({'get':'list','post':'create'})), #获取 ...
- drf偏移分页组件-游标分页-自定义过滤器-过滤器插件django-filter
drf偏移分页组件 LimitOffsetPagination 源码分析:获取参数 pahenations.py from rest_framework.pagination import Limit ...
- ibatis 实现 物理级别的 分页 兼容多种数据库(转载)
最近在看iBatis时,想做用动态Sql做个分布.因为在做项目时用iBator工具生成没有分页的功能,只有一些我们常用的功能.所以要对生成后的代码做修改.我在Java高手真经的一书中看到有做了MySq ...
- oracle ibatis 存储过程 返回游标 嵌套表
自己解决问题了 问题总结: 1.index by表不能存储在数据库中的type中,故选择嵌套表. 2.ibatis不支持oracle的复合数据类型的返回.(个人理解) 3.替代方案:用返回oracle ...
- solr研磨之游标分页
普通分页 当需要深度分页的时候,比如查询第10000页数据,每页显示10条,意味着需要提取前10000 x 10 页的数据,并将这100000条数据缓存在内存中,然后在内存中进行排序.最后返回最后10 ...
- Ibatis调用存储过程实现增删改以及分页查询
1.Ibatis实现增删改操作很简单了,通常我是将某一模块的增删改功能写在一个存储过程里,通过一个标识符去区分执行增加还是修改抑或删除操作. statement: <!-- 存储过程:实现学生的 ...
- IBatis的分页研究
IBatis的分页研究 博客分类: Ibatis学习 摘自: http://cpu.iteye.com/blog/311395 yangtingkun Oracle分页查询语句 ibaits. ...
- ASP.NET和MSSQL高性能分页
首先是存储过程,只取出我需要的那段数据,如果页数超过数据总数,自动返回最后一页的纪录: set ANSI_NULLS ON set QUOTED_IDENTIFIER ON GO -- ======= ...
随机推荐
- bootstrap -- 一个标签中,同时有 col-xs , col-sm , col-md , col-lg
.col-xs- 超小屏幕 手机 (<768px) .col-sm- 小屏幕 平板 (≥768px) .col-md- 中等屏幕 桌面显示器 (≥992px) .col-lg- 大屏幕 大桌面显 ...
- c pvr转存pvr.ccz格式
pvr.ccz 是把pvr用zlib算法压缩后的图像格式,其优点是可以提升文件读取效率. 大多数情况下我们可以用一些工具来将pvr压缩到pvr.ccz ,下面提供一个c++方法来完成这个过程 int ...
- Java笔记(二十七)……IO流中 File文件对象与Properties类
File类 用来将文件或目录封装成对象 方便对文件或目录信息进行处理 File对象可以作为参数传递给流进行操作 File类常用方法 创建 booleancreateNewFile():创建新文件,如果 ...
- 洛谷P1118 数字三角形游戏
洛谷1118 数字三角形游戏 题目描述 有这么一个游戏: 写出一个1-N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行这样的操作,显然每次构成的序列都比上一次的序列长度少1,直 ...
- 决策树及其python实现
剪枝 由于悲观错误剪枝 PEP (Pessimistic Error Pruning).代价-复杂度剪枝 CCP (Cost-Complexity Pruning).基于错误剪枝 EBP (Error ...
- 给新手的 10 个有用 Linux 命令行技巧
我记得我第一次使用 Linux 的时候,我还习惯于 Windows 的图形界面,我真的很讨厌 Linux 终端.那时候我觉得命令难以记忆,不能正确使用它们.随着时间推移,我意识到了 Linux 终端的 ...
- makeKeyAndVisible的功能
makeKeyAndVisible的作用 [self.window makeKeyAndVisible] 由于iPhone是单窗口程序,所以也就只有这么一个Window对象,而且是UIWindow,不 ...
- 【python自动化第十篇:】
复习: 线程与进程的区别: 进程:资源的集合 线程:最小调度单位 进程至少包含一个线程 线程之间的内存是共享的,两个线程操作同一个数据就会修改整个结果(需要mutex加锁来保持数据的一致性),递归锁, ...
- 如何在eclipse中安装Jess
如何在eclipse中安装Jess 浏览:49 | 更新:2014-05-12 16:39 这个文章帮了不少忙,感谢! 但经我实践,还要把插件那些文件向/dropins/sdk下也放一份,才能成功. ...
- Android 读取手机短信
获取android手机短信需要在AndroidManifest.xml加权限: <uses-permission android:name="android.permission.RE ...