伪列

本文详细介绍了Oracle数据库中的伪列特性,包括rowid用于去重、rownum实现分页查询及top-N分析,以及level用于递归查询的具体用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--伪列(针对Oracle数据库)


--rowid
--rownum
--level


--rowid
--去重
主键    列1   列2  列3
1        1     x   y
2        1     x   y
3        3     w   w   
4        4     q   q
5        4     q   q
6        5     p   p
delete from 表X
where rowid not in(select max(rowid) 表X group by 列1,列2,列3)


--rownum
select rownum,t.* from emp t
where rownum between 1 and 5

select * from emp limit 0,5(MySQL中可以,oracle不支持)

--rownum只能从一开始
select * from (select rownum as num,t.* from emp t)

where num between 6 and 10    


--top-N分析
--按工资排序
select * from (select rownum as num,t.* from emp  t order by sal desc)
where num between 1 and 5 
--发现第一不是King,这是由于num的添加在排序之前造成的   所以应该先排序,再嵌套个表


select * from (select rownum as num,t.* from (select * from emp order by sal desc) t)
where num between 1 and 5 


--工资前三的人信息
select * from (select * from emp order by sal desc)
where rownum <=3



--level  递归查询
select * from emp 
connect by | start with


--查询当前行mgr=前一行员工编号
select * from emp 
connect by mgr=prior empno   --递归条件  不满足即结束
start with mgr is null       --起止点


--level     --区分层级之间的关系
select level,t.* from emp t
connect by mgr=prior empno   
start with mgr is null

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蜗牛互联网

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值