Oracle之rownum(转载)

Oracle之rownum(转载),第1张

一、rownum的说明

rownum是oracle特有的一个关键字。

(1)对于基表,在insert记录时,oracle就按照insert的顺序,将rownum分配给每一行记录,因此在select一个基表的时候,rownum的排序是根据insert记录的顺序显示的,例如:

(2)对于子查询,则rownum的顺序是根据子查询的查询顺序进行动态分配的,例如:

由上图可以看到T1_RN和T2_RN的区别。

t1中的rownum是根据emp这个基表的默认顺序分配的,而内层子循环是根据SAL字段进行排序,所以t2的rownum是根据内层子查询的记录顺序分配的。

----------------------------- 分 割 线 -------------------------------------

二、rownum的一些使用技巧

(1)使用rownum限制查询返回的记录数

1、例如,我们现在只想看到emp表中的第一条记录:

将rownum限制为1,这样就只能查询出一条记录。

2、现在,我们现在想查看emp中的前2条记录:

将rownum的限制为2条,这样就可以查询出前2条记录。

3、假如我们现在只想查看emp中的第二条记录,又该如何写语句呢?

如果我们先这样写:

where条件为:rownum=2,来看看查询结果:

发现没有查出任何数据,为什么呢?这里就要对oracle的rownum做进一步的理解。

因为rownum并不是当作实体数据存放在每一张表中,而是在每一次select查询的时候,根据基表的默认insert顺序由oracle动态分配的,有1才有2,如果rownum没有1,那么2也就没有了意义,所以这个查询就不会有任何结果出来。这个时候我们就需要利用子查询和别名列来实现这个需求:

首先通过子查询,取出emp表的前2条记录,并将子查询中的rownum定义为别名rn,然后在外层查询中,使用where条件使rn=2即可,查询出emp表的第二条记录:

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。

1、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这就可以了

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)

这样就可以了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9665201.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存