oracle伪列ROWNUM的学习
1. ROWNUM 是按照记录插入时的顺序排序的
2. ROWNUM 并不实际存在,是对筛选后的结果集的一个排序,如果不存在结果集就不会有ROWNUM
3. ROWNUM 不能用基表名作为前缀
4. 在使用ROWNUM进行查询时
4.1 若使用大于号(>),则只能使用(>0),其他均不可以,用刚才的表做说明。
(a)查询rownum>0的数据
select rownum,xh,sex,birthday,classid,degree from stud
where rownum >0
和预期一样,显示了所有的记录
(b)查询rownum>1的数据
select rownum,xh,sex,birthday,classid,degree from stud
where rownum >1 (>N,N>=1)
为什么不显示ROWNUM=(2,3,4)的记录
说明:当select筛选出所要的结果集后,取出第一条ROWNUM=1,不符合ROWNUM>1,所以剔除,选取下面一条数据,ROWNUM仍然是1,还是不符合要求。以此类推,没有ROWNUM=1就没有ROWNUM=2,所以就不会筛选出ROWNUM>1的结果集。
(c)但是利用子查询就可以实现原来的想法
select * from (select rownum as rn,xh,sex,birthday,classid,degree from stud)
where rn>1
注意:此处需要使用别名
4.2 若使用小于号(<),同一般情况
4.3 若使用等于号(=),则只能使用等于1(=1),原因同4.1
5. 对于ROWNUM排序的实验说明
(a)执行四条插入语句,SQL 如下:
insert into stud values('A001','Jack','男','','10','');
insert into stud values('A002','Tom','男','','30','');
insert into stud values('A003','Jhon','女','','20','');
insert into stud values('A004','Martin','男','','20','');
commit;
(b)再进行查看,SQL 如下:
select rownum,xh,sex,birthday,classid,degree from stud;
结果如下:
(c)查看后三条记录,SQL 如下:
select rownum,xh,sex,birthday,classid,degree from stud
where xh in ('A002','A003','A004');
结果如下:
ROWNUM 是按照插入顺序得来的,但是上面第二次查询ROWNUM为什么不是2、3、4,或许有人会有这个疑问。由于ROWNUM并不是物理存在的,它是一个逻辑的顺序。当查询时,按条件得到 ’ A002 ’ 、 ’ A003 ’ 、 ’ A004 ’ 三条记录,oracle对查询得到的三条记录按照插入时的次序进行排序分别为1、2、3。
6 . 利用ROWNUM取出第2-3行数据,有两种方法:
方法一:先取出前3条记录,再取出第一条数据,用minus做差集就得到了需要的结果集
SQL 如下:
select rownum,xh,xm,sex,classid from stud
where rownum <=3
minus
select rownum,xh,xm,sex,classid from stud
where rownum =1;
结果如下:
方法二:不利用minus也可以,利用子查询
SQL 如下:
select * from (select rownum as rn,xh,xm,sex,classid from stud where rownum<=3)
where rn>1;
结果如下:
总结:方法二使用时,子查询rownum需要使用别名。在数据量较大的情况下,方法二效率较高。