oracle10g 里怎么查询结果集的第几条到第几条数据啊?
解决方案 »
- Oracle Olap api的开发问题(急)
- oracle创建用户,但在方案中没有对应的显示
- 如何将两个字段相同的表写成一个视图
- ####在线高分求助#### PL/SQL 菜鸟问题!!!!
- 怎样把一个用户创建的表以及sequences 等 对象,复制到另外一个用户下
- database configuration assistant 无法启动?重新安装了dca后还是不行?
- 修改系统时间,急!!!
- oracle9i安装程序三个文件下载完后,解压缩成三个*.cpio文件,应该再怎么办?
- 在ORACLE中如何按数据仓库进行数据库设计
- 我是来找组织的,这里有oracle sales cloud的实施人员吗?
- 请问:游标只能用于查询时显示结果记录的一行信息吗,能否用于其它数据库操作啊,比如insert,modify啊
- 求一sql写法!
Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用。
分页查询格式:
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 A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
)
WHERE RN BETWEEN 21 AND 40
对比这两种写法,绝大多数的情况下,第一个查询的效率比第二个高得多。