ibatis 实现 物理级别的 分页 兼容多种数据库(转载)
最近在看iBatis时,想做用动态Sql做个分布。因为在做项目时用iBator工具生成没有分页的功能,只有一些我们常用的功能。所以要对生成后的代码做修改。我在Java高手真经的一书中看到有做了MySql SqlServer Oracle的分页。实现如下:
MySql-->
首先说说MySql的分页语句
- select * from user where ... order by ... limit 10,25
根据以上的语句我们可以对ibator生成后的代码进行修改。
第一修改User_sqlMap.xml
修改前
- < select id = "ibatorgenerated_selectByExample" resultMap = "ibatorgenerated_BaseResultMap"
- parameterClass = "com.demo.ibatis.beans.UserExample" >
- select ID, LOGIN_NAME, PASSWORD
- from user
- < isParameterPresent >
- < include refid = "user.ibatorgenerated_Example_Where_Clause" />
- < isNotNull property = "orderByClause" >
- order by $orderByClause$
- </ isNotNull >
- </ isParameterPresent >
- </ select >
修改后
- < select id = "ibatorgenerated_selectByExample" resultMap = "ibatorgenerated_BaseResultMap"
- parameterClass = "com.demo.ibatis.beans.UserExample" >
- select ID, LOGIN_NAME, PASSWORD
- from user
- < isParameterPresent >
- < include refid = "user.ibatorgenerated_Example_Where_Clause" />
- < isNotNull property = "orderByClause" >
- order by $orderByClause$
- </ isNotNull >
- [b] < isNotNull property = "limitClauseStart" >
- limit
- $limitClauseStart$,$limitClauseCount$
- </ isNotNull > [/b]
- </ isParameterPresent >
- </ select >
重要的是黑色的字体是添加到原来的xml中的。接下来修改UserExample.java
在该类中添加两个字段和相应的getter/setter方法
- protected String limitClauseStart; //起始参数
- protected String limitClauseCount; //数量参数
接下来就可以通过Dao调用selectByExample()方法测试,好的以上就是MySql的分页。SqlServer的分页比较难了,因为 SqlServer中没有limit的关键字。
看看SqlServer的分页语句,那当然 SqlServer人分布方法有很多种。这里我采用其中的一种。
语句如下:
- SELECT TOP 页大小 *
- FROM TestTable
- WHERE (ID NOT IN
- ( SELECT TOP 页大小*页数 id
- FROM 表
- ORDER BY id))
- ORDER BY ID
接下来和上面的MySql一样也进行修改
修改xml
- < select id = "ibatorgenerated_selectByExample" resultMap = "ibatorgenerated_BaseResultMap"
- parameterClass = "com.demo.ibatis.beans.UserExample" >
- [b] < isNotNull property = "limitClauseStart" >
- SELETE TOP $limitClauseCount$ * FROM user where (ID NOT IN
- (SELECT TOP $limitClauseStart$ ID
- </ isNotNull > [/b]
- < isNull property = "limitClauseStart" >
- SELETE *
- </ isNull >
- FROM user
- from user
- < isParameterPresent >
- < include refid = "user.ibatorgenerated_Example_Where_Clause" />
- < isNotNull property = "orderByClause" >
- order by $orderByClause$
- [b] < isNotNull property = "limitClauseStart" >
- ))order by $orderByClause$
- </ isNotNull > [/b]
- </ isNotNull >
- </ isParameterPresent >
- </ select >
接下来是ORacle的,和上面都是差不多的这里不多说。
语法:
select* from(select rownum tid,user.* FROM (select * from user where id>1 order by ID desc)user where where rownum<35) where tid>10;
修改Xml,
- < select id = "ibatorgenerated_selectByExample" resultMap = "ibatorgenerated_BaseResultMap"
- parameterClass = "com.demo.ibatis.beans.UserExample" >
- [b] < isNotNull property = "limitClauseStart" >
- select* from(select rownum tid,user.* FROM (
- </ isNotNull > [/b]
- select * from user
- < isParameterPresent >
- < include refid = "user.ibatorgenerated_Example_Where_Clause" />
- < isNotNull property = "orderByClause" >
- order by $orderByClause$
- </ isNotNull >
- [b] < isNotNull property = "limitClauseStart" >
- <![[CDATA )user where where rownum<$limitClauseCount$+$limitClauseStart$+1) where tid>$limitClauseStart$;]]>
- </ isNotNull > [/b]
- </ isParameterPresent >
- </ select >
ibatis 实现 物理级别的 分页 兼容多种数据库(转载)的更多相关文章
- SQL 横转竖 、竖专横 (转载) 使用Dapper.Contrib 开发.net core程序,兼容多种数据库 C# 读取PDF多级书签 Json.net日期格式化设置 ASPNET 下载共享文件 ASPNET 文件批量下载 递归,循环,尾递归 利用IDisposable接口构建包含非托管资源对象 《.NET 进阶指南》读书笔记2------定义不可改变类型
SQL 横转竖 .竖专横 (转载) 普通行列转换 问题:假设有张学生成绩表(tb)如下: 姓名 课程 分数 张三 语文 74 张三 数学 83 张三 物理 93 李四 语文 74 李四 数学 84 ...
- 使用Dapper.Contrib 开发.net core程序,兼容多种数据库
关于Dapper的介绍,我想很多人都对它有一定的了解,这个类似一个轻型的ORM框架是目前应用非常火的一个东西,据说各方面的性能都不错,而且可以支持多种数据库,在开始介绍这个文章之前,我花了不少功夫来学 ...
- Dapper.Contrib 开发.net core程序,兼容多种数据库
Dapper.Contrib 开发.net core程序,兼容多种数据库 https://www.cnblogs.com/wuhuacong/p/9952900.html 使用Dapper.Contr ...
- Winform开发框架中实现同时兼容多种数据库类型处理
在很多应用系统里面,虽然一般采用一种数据库运行,但是由于各种情况的需要,可能业务系统会部署在不同类型的数据库上,如果开发的系统能够很方便支持多种数据库的切换,那可以为我们减少很多烦恼,同时提高系统的适 ...
- 关于ibatis进行物理游标分页
http://www.iteye.com/topic/136712 详细demo:参照http://www.kusoft.net 我的数据库是采用mssql2000 采用分页必定数据量比较大: 按照i ...
- 真正的让iframe自适应高度 兼容多种浏览器随着窗口大小改变
今天有朋友问到我关于"iframe自适应高度"的问题,原本以为是很简单的问题,没想到折腾了20分钟才搞定.期间遇到几个问题,要么是高度自适应了,但是当窗口改变时会出现滚动条.也就是 ...
- jDialects:一个从Hibernate抽取的支持70多种数据库方言的原生SQL分页工具
jDialects(https://git.oschina.net/drinkjava2/jdialects) 是一个收集了大多数已知数据库方言的Java小项目,通常可用来创建分页SQL和建表DDL语 ...
- 兼容多种模块规范(AMD,CMD,Node)的代码
在JavaScript模块化开发中,为了让同一个模块可以运行在前后端,以及兼容多种模块规范(AMD,CMD,Node),类库开发者需要将类库代码包装在一个闭包内. AMD规范 AMD,即“异步模块定义 ...
- 自定义兼容多种Protobuf协议的编解码器
<从零开始搭建游戏服务器>自定义兼容多种Protobuf协议的编解码器 直接在protobuf序列化数据的前面,加上一个自定义的协议头,协议头里包含序列数据的长度和对应的数据类型,在数据解 ...
随机推荐
- E20180331-hm
corresponding adj. 相当的,对应的; 通信的; 符合的,符合; 一致的; implicitly adv. 含蓄地; 暗示地; 无疑问地; 无保留地; causal adj. 具有因 ...
- 洛谷 - P2945 - 沙堡Sand Castle - 排序
https://www.luogu.org/problemnew/show/P2945 好像猜一猜就觉得排序之后是最优的,懒得证明了.每个城墙向他最接近的城墙靠近,绝对是最优的.
- 洛谷 - P1355 - 神秘大三角 - 简单计算几何
https://www.luogu.org/problemnew/show/P1355 判断一个点和三角形的位置关系,最简单的思路就是用向量. 首先排除掉和三角形顶点重合的情况. 把三角形设计成一个首 ...
- (水题)洛谷 - P1996 - 约瑟夫问题 - 链表
https://www.luogu.org/problemnew/show/P1996 试了一下数组实现的双向链表,是挺难用的,估计是应该写个get_next()函数比直接用next数组好. #inc ...
- POJ1236【图的前连通(缩点)】
题意: 1.初始至少需要向多少个学校发放软件,使得网络内所有的学校最终都能得到软件. 2.至少需要添加几条传输线路(边),使任意向一个学校发放软件后,经过若干次传送,网络内所有的学校最终都能得到软件. ...
- 洛谷P2219 [HAOI2007]修筑绿化带(单调队列)
传送门 啧……明明以前做到过这种类型的题结果全忘了…… 这种矩阵的,一般都是先枚举行,然后对列进行一遍单调队列,搞出右下角在每一行中合法位置时的最小权值 再枚举列,对行做一遍单调队列,用之前搞出来的最 ...
- 在 React项目中使用 bootstrap
在使用create-react-app 创建的项目中使用 bootstrap; 安装react-bootstrap; npm install react-bootstrap --savenpm ins ...
- 关于ios7 以上版本 view被导航栏遮挡的问题 解决方案
self.edgesForExtendedLayout = UIRectEdgeNone; 如果导航栏是默认带磨砂透明效果的,使用了edgesForExtendedLayout可能会出现导航栏变不透明 ...
- hdu 5409 CRB and Graph(边双联通分量)
题意: 给一个图一些边,保证图连通 问对于每条边,如果去除该边后使得图中一些点不连通.设这些点(u,v),要求使u尽量小,v尽量大,输出这样的(u,v).否则输出0 0. #include <b ...
- mui.init()方法中可以有子页面和预加载两项内容,它们是否都在页面加载完成时创建其对应的webview对象?
subpages和preloadPages区别是什么? mui.init({ subpages: [{ url: 'subject.html', //子页面HTML地址,支持本地地址和网络地址 id: ...