Oracle分页实现
2013-04-23 09:50
155 查看
简单分析下如何实现:
考虑mySql中的实现分页,select * from 表名 limit 开始记录数,显示多少条;就可以实现我们的分页效果。
但是在oracle中没有limit关键字,但是有 rownum字段
rownum是一个伪列,是oracle系统自动为查询返回结果的每行分配的编号,第一行为1,第二行为2,以此类推。。。。
第一种:
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21
其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN >= 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM <= 40这句上。
选择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。
第二种:
select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r>21 and e1.r<=40;
红色部分:按照工资降序排序并查询所有的信息。 --(select * from emp order by sal desc)
棕色部分:得到红色部门查询的值,并查询出系统的rownum并指定上别名。这一句就比较关键,起了一个过渡的作用,首先要算出rownum来对红色部分指定上序号,也可以为蓝色外面部分用到这个变量。指定上查询的开始记录数和结束记录的条件。--select e.*,rownum r from ()
蓝色部分:指定记录从第几条开始到第几条结束,取出棕色部门的值来作为查询条件的变量---select * from (()e ) e1 where e1.r>21 and e1.r<=40;
总结:绝大多数的情况下,第一个查询的效率比第二个高得多。
考虑mySql中的实现分页,select * from 表名 limit 开始记录数,显示多少条;就可以实现我们的分页效果。
但是在oracle中没有limit关键字,但是有 rownum字段
rownum是一个伪列,是oracle系统自动为查询返回结果的每行分配的编号,第一行为1,第二行为2,以此类推。。。。
第一种:
SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21
其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN >= 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM <= 40这句上。
选择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。
第二种:
select * from (select e.*,rownum r from (select * from emp order by sal desc) e ) e1 where e1.r>21 and e1.r<=40;
红色部分:按照工资降序排序并查询所有的信息。 --(select * from emp order by sal desc)
棕色部分:得到红色部门查询的值,并查询出系统的rownum并指定上别名。这一句就比较关键,起了一个过渡的作用,首先要算出rownum来对红色部分指定上序号,也可以为蓝色外面部分用到这个变量。指定上查询的开始记录数和结束记录的条件。--select e.*,rownum r from ()
蓝色部分:指定记录从第几条开始到第几条结束,取出棕色部门的值来作为查询条件的变量---select * from (()e ) e1 where e1.r>21 and e1.r<=40;
总结:绝大多数的情况下,第一个查询的效率比第二个高得多。
相关文章推荐
- Oracle创建视图实现获取当前数据所在的页数,这里以每页2条数据分页
- Oracle、MySQL、SQLServer实现分页
- oracle实现存储过程的分页并用java代码调用存储过程
- oracle的分页查询的实现
- Oracle和mysql在实现分页上不同
- oracle怎么实现分页比较好
- Oracle 实现分页查询功能
- Oracle 存储过程调用 返回结果集 实现分页
- MyBatis学习(九)-MyBatis分页实现 - Oracle(二)
- oracle实现分页以及性能分析
- MyBatis拦截器实现mysql与oracle共用分页
- java ssm框架实现分页功能的示例代码(oracle)
- .net+oracle 实现分页 和 菜单
- Spring +Mybatis +oracle 实现数据库分页
- ORACLE用LIMIT实现类似分页
- oracle 实现分页
- oracle实现分页总结
- MySQL、SqlServer、Oracle三大主流数据库实现分页查询的方法
- MySQL和Oracle分页查询实现方式
- 一个简单的oracle分页存储过程的实现和调用