Exists and IN, Not Exists and Not IN, LAG() and LEAD()

select distinct score_level from t_test order by score_level;

create table T_SCORE_LEVEL(level_id int, level_name varchar2(30));

insert into T_SCORE_LEVEL values(1,'Excelent');
insert into T_SCORE_LEVEL values(2,'Good');
insert into T_SCORE_LEVEL values(3,'Passed');
insert into T_SCORE_LEVEL values(4,'NonPassed');
insert into T_SCORE_LEVEL values(null,'Worse');

--The example of the subquery in ORDER BY statement
select score_level,max(score),min(score) from t_test group by score_level
--left outer join T_SCORE_LEVEL on T_SCORE_LEVEL.LEVEL_ID = t_test.score_level
order by (select T_SCORE_LEVEL.LEVEL_NAME from T_SCORE_LEVEL where T_SCORE_LEVEL.LEVEL_ID =t_test.score_level);

update t_test set score_level= 5 where score<40;


--Difference between EXISTS and IN, Not Exists and Not IN
select count(*) from t_test where not exists (select * from t_score_level where t_score_level.level_id = t_test.score_level);

select count(*) from t_test where t_test.score_level not in (select level_id from t_score_level);

select count(*) from t_test where exists (select * from t_score_level where t_score_level.level_id = t_test.score_level);

select count(*) from t_test where t_test.score_level in (select level_id from t_score_level);


select count(*) from t_test left outer join t_score_level on t_score_level.level_id = t_test.score_level;

select level_id from t_score_level order by level_id desc;

select * from t_score_level where exists (select null from dual);
select * from t_score_level where not exists (select null from dual);

select * from t_test where exists (select null from dual);
select * from t_test where not exists (select null from dual);

select * from t_score_level t1 where not exists (select null from t_score_level t2 where t1.level_id=t2.level_id);
select * from t_score_level t1 where  t1.level_id  not in (select t2.level_id from t_score_level t2);

select * from t_score_level t1 where exists (select 1 from t_score_level t2 where t1.level_id=t2.level_id);
select * from t_score_level t1 where  t1.level_id  in (select t2.level_id from t_score_level t2);

--the example for funcation LAG() and LEAD()
with a as (select 1 id,'a' name from dual
union
select 2 id,'b' name from dual
union
select 23 id,'c' name from dual
union
select 14 id,'d' name from dual
union
select 8 id,'e' name from dual
 )
select id,name,lag(id,2,'') over(order by name),lead(id,1,'')over(order by name) from a

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值