Mysql和oracle的分页问题
2015-09-06 15:02
459 查看
因为之前一直用的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就可以了。
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就可以了。
相关文章推荐
- oracle 存储过程 技巧
- oracle sql语句优化
- Oracle中HWM与数据库性能的探讨
- 32位win7下安装Oracle10g(10.2.0.1)和补丁Patch(10.2.0.4)笔记
- Oracle 11g oracle客户端(32位)PL/SQL develepment的安装配置
- oracle添加新用户
- plsql连接数据库ora-28547 oracle net 管理错误
- Oracle GoldenGate 简介 数据库同步 异地复制方案
- oracle中的buffer cache
- ORACLE分页查询SQL语法——最高效的分页
- oracle RMAN克隆数据库
- PLSQL怎样导出oracle表结构和数据
- Oracle定时调用存储过程
- VS本地调试oracle报错解决方法
- oracle数据库导入导出命令!
- oracle数据导入导出
- 使用存储过程将Oracle数据批量导出为多个csv文件
- 批量快速的导入导出Oracle的数据(spool缓冲池、java实现)
- oracle官网下载jdk各版本地址
- Oracle创建Sequence时Order/NoOrder选项