Oracle -Mybatis动态SQL查询分页的实现

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle -Mybatis动态SQL查询分页的实现相关的知识,希望对你有一定的参考价值。

首先看SQL 怎么写

 select *
          from
          (
          select a.*,ROWNUM rn
          from (
           最底层查询语句
              )  a
                where ROWNUM <= #{endCol}
            )
            where rn > #{startCol}

注意:Mybatis中 < 是小于号  >是大于号

当然 我们还需要 select count(*) 最底层查询语句来得到结果集的总数。然后再换算出 endCol 和 startCol

换算代码如下:

//int totalRecord= 总条数;
            //计算分页
            int intPS=Integer.parseInt(pageSize);
            int intPN= Integer.parseInt(pageNo);
            int intStartCol= intPS*(intPN-1)+1;
            int intEndCol= intPS*intPN-1+1;
            String startCol= String.valueOf(intStartCol);
            String endCol=String.valueOf(intEndCol);
            
            int totalPageNo=totalRecord%intPS>0?totalRecord/intPS+1:totalRecord/intPS;
            //在参数字典中加入分页的起始和结束条目号
            paramsMap.put("startCol",startCol);
            paramsMap.put("endCol", endCol);

 

以上是关于Oracle -Mybatis动态SQL查询分页的实现的主要内容,如果未能解决你的问题,请参考以下文章

如何下载oracle11g

oracle周数计算

oracle 安装

什么是oracle的实例

ORACLE 官方只可以下载oracle11g 版本的数据库 没有了ORACLE 10g 是否ORACLE 10g 过期了 不能在官方下载

oracle主目录路径不能包含空格