Chinaunix首页 | 论坛 | 博客
  • 博客访问: 103739699
  • 博文数量: 19283
  • 博客积分: 9968
  • 博客等级: 上将
  • 技术积分: 196062
  • 用 户 组: 普通用户
  • 注册时间: 2007-02-07 14:28
文章分类

全部博文(19283)

文章存档

2011年(1)

2009年(125)

2008年(19094)

2007年(63)

分类: Oracle

2008-04-21 10:35:55

    来源:赛迪网    作者:Drew

虽然Oracle数据库并不支持TOP关键字:但它提供了rownum这个隐式游标,可以实现与TOP类似的功能。

示例如下:

SELECT TOP 10 ... FROM WHERE ...

要写成

SELECT ... FROM ... WHERE ... AND rownum <= 10

rownum 是记录序号(1,2,3...),注意:如果 SQL 语句中有 ORDER BY ... 排序的时候,rownum 居然是先“标号”后排序!这样,这个序号如果不加处理是不合乎使用需求的。

至于临时表,Oracle数据库的临时表和SQL Server的有很大不同。

分页示例:

SELECT * FROM

(

SELECT A.*, rownum r

FROM

(

SELECT *

FROM Articles

ORDER BY PubTime DESC

) A

WHERE rownum <= PageUpperBound

) B

WHERE r > PageLowerBound;

阅读(199) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~