Mysql和oracle的分页问题

           因为之前一直用的oracle,习惯了使用oracle的伪列来进行分页的时候,一般查询分页的数据是这样的:

            select * from (select a.*,rownum as rn from ( select  * from 表名 where 条件  order      by  属性名  desc ) a where rownum<=14) where rn>=1 ;

         所以从这可以看出,oracle把每行的数据看作一个伪列,也就是rownum,那么查出来的数据就是按照列来排序的,所以当我们进行分页的时候计算页面要显示的每个页的数据的时候应该是:伪列的最大是应该是:(currentpage*pagesize),伪列的最小值值应该为:(currentpage-1)*pagesize,这样就能计算出按照伪列来取出分页的每页的正确数据,而我们只需要传入当前页和总页数大小就可以。



        然而mysql使用的是从第几行开始,它没有oralce这种伪列的概念,:

        select * from 表名  limit   0,4。(mysql第一条数据是从0开始,oralce伪列是从1开始)第一个参数这就表示第几行数据开始,显示多少条数据,这就比oracle直观一点,这对于使用了过久地oracle的我是个大坑啊!用的mybatis一直以为是Mybatis的问题,经过测试才发现这是语句问题。哎,治学还是要严谨。所以,mysql分页就简单了,指定第几行数据,然后每页多少条,limit   (curretpage-1)*pagesize , pagesize就可以了。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值