rownum和rowid都是伪列,可是二者的根本是不一样的,rownum是根据sql查询出的结果给每行分配一个逻辑编号,因此你的sql不一样也就会致使最终rownum不一样,可是rowid是物理结构上的,在每条记录insert到数据库中时,都会有一个惟一的物理记录 ,
例如 AAAMgzAAEAAAAAgAAB 7499 ALLEN SALESMAN 7698 1981/2/20 1600.00 300.00 30
这里的AAAMgzAAEAAAAAgAAB物理位置对应了这条记录,这个记录是不会随着sql的改变而改变。
所以,这就致使了他们的使用场景不一样了,一般在sql分页时或是查找某一范围内的记录时,咱们会使用rownum。
一、rownum
例如:
查找2到10范围内的记录(这里包括2和10的记录)
select *
from (select rownum rn, a.* from emp a) t
where t.rn between 2 and 10;
查找前三名的记录
select * from emp a where rownum < 3;这里咱们要注意,直接用rownum查找的范围必需要包含1;由于rownum是从1开始记录的,固然你能够把rownum查出来后放在一个虚表中做为这个虚表的字段再根据条件查询。
例如:
select *
from (select rownum rn, a.* from emp a) t
where t.rn > 2;这就能够了
二、rowid
咱们在处理一张表中重复记录时常常用到他,固然你也能够用一个很原始的方法,就是将有重复记录的表中的数据导到另一张表中,最后再倒回去。
SQL>create table stu_tmp as select distinct* from stu;
SQL>truncate table sut; //清空表记录
SQL>insert into stu select * from stu_tmp; //将临时表中的数据添加回原表可是要是stu的表数据是百万级或是更大的千万级的,那这样的方法显然是不明智的,所以咱们能够根据rowid来处理,rowid具备惟一性,查询时效率是很高的,
例如,学生表中的姓名会有重复的状况,可是学生的学号是不会重复的,若是咱们要删除学生表中姓名重复只留学号最大的学生的记录,怎么办呢?
delete from stu a
where rowid not in (select max(rowid)
from stu b
where a.name = b.name
and a.stno < b.stno);
这样就能够了。
sql