ORACLE中ROWNUM
一、rownum
1、rownum是对结果集添加的一个伪列;
2、是先按某种条件查询出结果集之后又添加上的一个列;
3、它总是从1开始,因此在使用的过程中需要谨慎使用>,>=,=,between...and这些条件。
eg:
如下语句,执行此条语句你会发现就算表中有数据,查出的结果集也是空,是因为当取出第一条数据,此时ROWNUM = 1,不满足ROWNUM > 10的条件,一次舍去,再取出下一条数据此时ROWNUM还会被赋值为1,依次类推,取到最后也还是没有。
SELECT ROWNUM,t.ownername FROM SYS_USER t
WHERE ROWNUM >10
二、说明
1、ROWNUM 和 ROWID虽都被称为伪列,但它们的存在方式是不一样的,rowid 可以说是物理存在的,表示记录在表空间中的唯一位置ID,在DB中唯一。只要记录没被搬动过,rowid是不变的。rowid 相对于表来说又像表中的一般列,所以以 rowid 为条件就不会有 rownum那些情况发生。
2、另外还要注意:rownum不能以任何基表的名称作为前缀
本文来自博客园,作者:楠楠之歌,转载请注明原文链接:https://www.cnblogs.com/htblog/p/15716564.html