ORACLE中用rownum分页并排序的SQL语句
2016-01-04 17:46
330 查看
ORACLE中用rownum分页并排序的SQL语句
以前分页习惯用这样的SQL语句:
结果发现由于该语句会先生成rownum 后执行order by 子句,因而排序结果根本不对,后来在GOOGLE上搜到一篇文章,原来多套一层select 就能很好的解决该问题,特此记录,语句如下:
==== 参考 ====
http://yangtingkun.itpub.net/post/468/100278
Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用。分页查询格式:
其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM <= 40和RN >= 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM <= 40这句上。
选择第21 到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。这是,查询语句如下:
对比这两种写法,绝大多数的情况下,第一个查询的效率比第二个高得多。
http://www.javaworld.com.tw/jute/post/view?bid=21&id=52022&sty=1&tpg=1&age=-1
以前分页习惯用这样的SQL语句:
http://yangtingkun.itpub.net/post/468/100278
Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用。分页查询格式:
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM <= 40这句上。
选择第21 到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM <= 40来控制最大值,在查询的最外层控制最小值。而另一种方式是去掉查询第二层的WHERE ROWNUM <= 40语句,在查询的最外层控制分页的最小值和最大值。这是,查询语句如下:
http://www.javaworld.com.tw/jute/post/view?bid=21&id=52022&sty=1&tpg=1&age=-1
相关文章推荐
- Oracle表空间不足
- 游标变量REF COUSOR(动态游标)使用实例
- oracle-sql server
- linux下安装配置oracle
- Windows Oracle ODBC安装配置
- Linux平台Oracle ODBC安装使用
- oracle 查看建表语句
- Oracle 的 rownum
- IT忍者神龟之Oracle DBA经常使用查询吐血列举
- Oracle 创建表
- 使用ROracle从Oracle数据库获取数据框
- SAP R3 Oracle 9i ORA-06413 连接未打开错误
- 【转】Oracle TYPE OBJECT(2)
- MySQL模拟Oracle的Sequence两种方法
- OracleHelper类
- Oracle的rollup、cube、grouping sets函数
- 类型:Oracle;问题:oracle 时间加减;结果:ORACLE 日期加减操作
- oracle 树状查询
- oracle修改字符集方法
- 用命令建oracle数据库实例