oracle中的rownum

1.oracle存在rownum关键字,它是一个伪列(系统分配在结果集上的一个特殊列)  

SELECT * FROM  oracleTable WHERE ROWNUM=1

上面这条语句是能够查询出第一行的记录的。

SELECT * FROM oracleTable WHERE ROWNUM>1

上面这条语句是查询不到任何数据的:

总结如下:

因为rownum总是从1开始,比如一个结果集的rownum序号是1,2,3....N,当你想查询rownum>1的记录时,系统判断第一条记录不满足,就会排除第一条记录,系统会把第二条记录的rownum置为1( 之前是2)。接着判断第二条记录是否rownum>1,结果发现不满足条件(因为第二条记录的rownum在之前被置为1了),接着排除第二条,系统把第三条记录的rownum置为1....

所以永远都不会满足rownum>1的条件

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。