最近在看iBatis时,想做用动态Sql做个分布。因为在做项目时用iBator工具生成没有分页的功能,只有一些我们常用的功能。所以要对生成后的代码做修改。我在Java高手真经的一书中看到有做了MySql SqlServer Oracle的分页。实现如下: 
MySql--> 
首先说说MySql的分页语句

  1. select  *  from   user   where ... order   by ... limit 10,25

    根据以上的语句我们可以对ibator生成后的代码进行修改。 
    第一修改User_sqlMap.xml 
    修改前

  1. < select   id = "ibatorgenerated_selectByExample"           resultMap = "ibatorgenerated_BaseResultMap"
  2. parameterClass = "com.demo.ibatis.beans.UserExample" 
  3. select ID, LOGIN_NAME, PASSWORD
  4. from user
  5. < isParameterPresent > 
  6. < include   refid = "user.ibatorgenerated_Example_Where_Clause"   /> 
  7. < isNotNull   property = "orderByClause" 
  8. order by $orderByClause$
  9. </ isNotNull > 
  10. </ isParameterPresent > 
  11. </ select > 

修改后

  1. < select   id = "ibatorgenerated_selectByExample"   resultMap = "ibatorgenerated_BaseResultMap"
  2. parameterClass = "com.demo.ibatis.beans.UserExample" 
  3. select ID, LOGIN_NAME, PASSWORD
  4. from user
  5. < isParameterPresent > 
  6. < include   refid = "user.ibatorgenerated_Example_Where_Clause"   /> 
  7. < isNotNull   property = "orderByClause" 
  8. order by $orderByClause$
  9. </ isNotNull > 
  10. [b] < isNotNull   property = "limitClauseStart" 
  11. limit
  12. $limitClauseStart$,$limitClauseCount$
  13. </ isNotNull > [/b]
  14. </ isParameterPresent > 
  15. </ select > 

重要的是黑色的字体是添加到原来的xml中的。接下来修改UserExample.java 
在该类中添加两个字段和相应的getter/setter方法

  1. protected  String limitClauseStart; //起始参数
  2. protected  String limitClauseCount; //数量参数

接下来就可以通过Dao调用selectByExample()方法测试,好的以上就是MySql的分页。SqlServer的分页比较难了,因为 SqlServer中没有limit的关键字。 
看看SqlServer的分页语句,那当然 SqlServer人分布方法有很多种。这里我采用其中的一种。 
语句如下:

  1. SELECT   TOP  页大小 *
  2. FROM  TestTable
  3. WHERE  (ID  NOT   IN
  4. SELECT   TOP  页大小*页数 id
  5. FROM  表
  6. ORDER   BY  id))
  7. ORDER   BY  ID

接下来和上面的MySql一样也进行修改 
修改xml

  1. < select   id = "ibatorgenerated_selectByExample"   resultMap = "ibatorgenerated_BaseResultMap"
  2. parameterClass = "com.demo.ibatis.beans.UserExample" 
  3. [b]  < isNotNull   property = "limitClauseStart" 
  4. SELETE TOP $limitClauseCount$ * FROM user where (ID NOT IN
  5. (SELECT TOP $limitClauseStart$ ID
  6. </ isNotNull > [/b]
  7. < isNull   property = "limitClauseStart" 
  8. SELETE *
  9. </ isNull > 
  10. FROM user
  11. from user
  12. < isParameterPresent > 
  13. < include   refid = "user.ibatorgenerated_Example_Where_Clause"   /> 
  14. < isNotNull   property = "orderByClause" 
  15. order by $orderByClause$
  16. [b]   < isNotNull   property = "limitClauseStart" 
  17. ))order by $orderByClause$
  18. </ isNotNull > [/b]
  19. </ isNotNull > 
  20. </ isParameterPresent > 
  21. </ 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,

    1. < select   id = "ibatorgenerated_selectByExample"       resultMap = "ibatorgenerated_BaseResultMap"
    2. parameterClass = "com.demo.ibatis.beans.UserExample" 
    3. [b]  < isNotNull   property = "limitClauseStart" 
    4. select* from(select rownum tid,user.* FROM (
    5. </ isNotNull > [/b]
    6. select * from user
    7. < isParameterPresent > 
    8. < include   refid = "user.ibatorgenerated_Example_Where_Clause"   /> 
    9. < isNotNull   property = "orderByClause" 
    10. order by $orderByClause$
    11. </ isNotNull > 
    12. [b]   < isNotNull   property = "limitClauseStart" 
    13. <![[CDATA )user where where rownum<$limitClauseCount$+$limitClauseStart$+1) where tid>$limitClauseStart$;]]>
    14. </ isNotNull > [/b]
    15. </ isParameterPresent > 
    16. </ select > 

ibatis 实现 物理级别的 分页 兼容多种数据库(转载)的更多相关文章

  1. SQL 横转竖 、竖专横 (转载) 使用Dapper.Contrib 开发.net core程序,兼容多种数据库 C# 读取PDF多级书签 Json.net日期格式化设置 ASPNET 下载共享文件 ASPNET 文件批量下载 递归,循环,尾递归 利用IDisposable接口构建包含非托管资源对象 《.NET 进阶指南》读书笔记2------定义不可改变类型

    SQL 横转竖 .竖专横 (转载)   普通行列转换 问题:假设有张学生成绩表(tb)如下: 姓名 课程 分数 张三 语文 74 张三 数学 83 张三 物理 93 李四 语文 74 李四 数学 84 ...

  2. 使用Dapper.Contrib 开发.net core程序,兼容多种数据库

    关于Dapper的介绍,我想很多人都对它有一定的了解,这个类似一个轻型的ORM框架是目前应用非常火的一个东西,据说各方面的性能都不错,而且可以支持多种数据库,在开始介绍这个文章之前,我花了不少功夫来学 ...

  3. Dapper.Contrib 开发.net core程序,兼容多种数据库

    Dapper.Contrib 开发.net core程序,兼容多种数据库 https://www.cnblogs.com/wuhuacong/p/9952900.html 使用Dapper.Contr ...

  4. Winform开发框架中实现同时兼容多种数据库类型处理

    在很多应用系统里面,虽然一般采用一种数据库运行,但是由于各种情况的需要,可能业务系统会部署在不同类型的数据库上,如果开发的系统能够很方便支持多种数据库的切换,那可以为我们减少很多烦恼,同时提高系统的适 ...

  5. 关于ibatis进行物理游标分页

    http://www.iteye.com/topic/136712 详细demo:参照http://www.kusoft.net 我的数据库是采用mssql2000 采用分页必定数据量比较大: 按照i ...

  6. 真正的让iframe自适应高度 兼容多种浏览器随着窗口大小改变

    今天有朋友问到我关于"iframe自适应高度"的问题,原本以为是很简单的问题,没想到折腾了20分钟才搞定.期间遇到几个问题,要么是高度自适应了,但是当窗口改变时会出现滚动条.也就是 ...

  7. jDialects:一个从Hibernate抽取的支持70多种数据库方言的原生SQL分页工具

    jDialects(https://git.oschina.net/drinkjava2/jdialects) 是一个收集了大多数已知数据库方言的Java小项目,通常可用来创建分页SQL和建表DDL语 ...

  8. 兼容多种模块规范(AMD,CMD,Node)的代码

    在JavaScript模块化开发中,为了让同一个模块可以运行在前后端,以及兼容多种模块规范(AMD,CMD,Node),类库开发者需要将类库代码包装在一个闭包内. AMD规范 AMD,即“异步模块定义 ...

  9. 自定义兼容多种Protobuf协议的编解码器

    <从零开始搭建游戏服务器>自定义兼容多种Protobuf协议的编解码器 直接在protobuf序列化数据的前面,加上一个自定义的协议头,协议头里包含序列数据的长度和对应的数据类型,在数据解 ...

随机推荐

  1. 从mysql高可用架构看高可用架构设计

    高可用HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间. 假设系统一直能够提供服务,我们说系统的可用性是100%.如果 ...

  2. hdoj5842【水题】

    比赛的时候还特别撒比地写了二分的那个写法,然后wa了一发,因为这个集合的翻译成自然数集.还是转换了一下,还是去写了一个二分. 后面就是出现几种就是多长... 比赛的真的非常非常挫的code-. #in ...

  3. POJ3258【二分】

    题意: 问一个河岸,两岸之间有笔直的n块石头,然后拔起(也可以施展魔法)m个石块,假设两岸也是石块,求处理过的石块的最小距离的最大. 思路: 他让我们求移开m个石块,无非是在n+2-m(已经把两岸看成 ...

  4. <TLE>奇偶剪枝hdoj1010

    (奇偶剪枝)转自百度百科,讲的非常棒: http://baike.baidu.com/link?url=3g5bW7LszRVOVvFDFp6cL0ZZnAaOLUdpaNjc2leHoxkKU9Eh ...

  5. POJ2488【DFS】

    阿西吧,搞清楚谁是行,谁是列啊!!! #include <stdio.h> #include <string.h> #include <math.h> #inclu ...

  6. Unity陀螺仪

    using UnityEngine; using System.Collections; using UnityEngine.UI; //摄像机 陀螺仪转动 public class TGyro : ...

  7. Cg(C for Graphic)语言表达式与控制语句(转)

    摘抄“GPU Programming And Cg Language Primer 1rd Edition” 中文名“GPU编程与CG语言之阳春白雪下里巴人” 在上一章中,我们已经介绍了 Cg 语言的 ...

  8. Luogu P1262 间谍网络 【强连通分量/缩点】By cellur925

    题目传送门 真是一道好题呀~~~~qwq 知道这题是tarjan,但是想了很久怎么用上强连通分量.因为样例们...它显然并不是一个强联通分量! (被样例迷惑的最好例子) 然后...就没有然后了...感 ...

  9. Codeforces Round #325 (Div. 2)

    水 A - Alena's Schedule /************************************************ * Author :Running_Time * Cr ...

  10. 水题 Codeforces Round #303 (Div. 2) D. Queue

    题目传送门 /* 比C还水... */ #include <cstdio> #include <algorithm> #include <cstring> #inc ...