通过rownum隐式游标实现与TOP相似的功能

王朝other·作者佚名  2008-06-01
窄屏简体版  字體: |||超大  

虽然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;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航