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



2008-04-21 12:49:08 北京时间
虽然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;




发表评论

请文明参与讨论,禁止漫骂攻击。本站保留不刊登无关和不雅评论的权力。


用户名: 密码: 匿名

相关新闻
由于工程需要经常将客户的现场数据导出到公司的开发环境中,随着
在对数据库进行操作过程中我们可能会遇到这种情况,表中的数据可
根据NULL的定义,NULL表示的是未知,因此两个NULL比较的结果既不
ORACLE 数据库有三种标准的备份方法,它们分别为导出/导入(EXPO
近来公司技术,研发都在问我关于内存参数如何设置可以优化Oracle

广告
© 2008 The Czz5 Company. All Rights Reserved. 关于我们 - 联系我们 - 广告业务 - 网站地图 - 版权声明 - 友情连接 - 网站投稿 - 致信编辑