Oracle学习记录 三 多语句

  1. UNION和UNION ALL

select deptno from emp

union

select deptno from dept;

相当于这两个结果取并集,union去掉重复的,union all保留重复的

2. intersect

select deptno from emp

intersect

select deptno from dept;

这相当于两个结果取交集。

3. minus

select deptno from dept

minus

select deptno from emp;

这和上面的两个有区别,第一个先用的dept,第二个是emp,这个的意思是取出dept中的结果,如果emp中也有这个

那么就去掉这个。

4. 一个结果集作为另一个的源

select sum(sal) from emp

where deptno in

(select deptno from dept

where loc='DALLAS');

loc为DALLAS的deptno的sal和

5. exists

select deptno from dept

where exists

(select deptno from emp

where deptno=40);

这个是如果括号内的语句有结果,那么就执行外面的语句,如果没有就不执行,这里就不会执行,因为emp中deptno没有40

这个值。

6. case

select deptno, case deptno

when 10 then sal+100

when 20 then sal - 100

else sal

end

"new sal"

from emp;

这就相当于if else,分情况处理

7. 下面这个算排名,我看着有点晕的乎的

select t1.ename, t1.sal, count(t2.sal) rank

from emp t1, emp t2

where t1.sal<=t2.sal or (t1.sal=t2.sal and t1.ename=t2.ename)

group by t1.ename, t1.sal

order by t1.sal desc, t1.ename desc;

我大概描述一下就是,把这个表抽象成两个,在where那比较t1.sal<=t2.sal,这样在前面count(t2.sal)就可以知道有

多少个比t1.sal大的了,也就得到了这个排名

你可能感兴趣的:(Oracle学习记录 三 多语句)