Oracle分页查询SQL实现

首先看SQL 怎么写

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

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

当然 我们还需要 select count(*) 最底层查询语句来得到结果集的总数。需要注意的是,在底层查询语句中,一定要加order by语法进行结果排序,分页会毫无意义。序然后再换算出 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);

 

转载于:https://www.cnblogs.com/oshushu/p/5163623.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值