《SQL CookBook》 简单查询汇总

    下载了《SQL CookBook》,认真专研一下,基础是很重要的,是时候拾回那些悄悄溜走的知识了。

1.       查询结果排序

 

1.1    显示部门10中的员工名字、职位和工资,并按照工资的升序排列。

select ename,job,sal from emp order by sal asc;

 

1.2    EMP表中,首先按照DEPTNO的升序排序,然后按照工资的降序排列。

select empno,deptno,sal,ename,job from emp order by deptno asc,sal desc

 

1.3 EMP表中返回员工名字和职位,并且按照职位字段的最后两个字符排序。

select ename,job from emp order by substr(job,length(job)-2);

 

1.3    EMP中根据COMM排序结果,处理控制排在最后。

select ename,sal,comm from ( select ename,sal,comm ,case when comm is null  then 1 else 0 end as is_null from emp) x order by is_null,comm;

 

1.4    如果JOB 是“SALESMAN,要根据COMM来排序。否则,根据SAL排序。

select ename,sal,job,comm

    -> from emp

    -> order by

    -> case when job='SALESMAN' then comm

-> else sal end;

 

2.      操作多个表

 

2.1    要显示EMP表部门10中员工的名字和部门编号,以及DEPT表中每个部门的名字和部门编号。

mysql> select ename as ename_and_dname,deptno from emp where deptno=10

    -> union all

    -> select line,null from t1

    -> union all

-> select dname,deptno from dept;

 

2.2    显示部门10 中所有员工的名字,以及每个员工所在部门的工作地点。

select ename,loc rom emp e,dept d where e.deptno = d.deptno and e.deptno = 10;

 

select ename,loc from emp e join dept d on(e.deptno=d.deptno) where e.deptno = 10; (等值内联)

2.3    从表DEPT中查找在表EMP中不存在数据的所有部门。

mysql> select deptno

    -> from dept d

    -> where not exists

-> (select null from emp e where d.deptno=e.deptno);

 

子查询关注的不是返回结果,而是两个表之间的关系,所以是查询null

1.       有对应关系,则有返回,not exists false,对于最外层查询则无结果;

2.       没对应关系,则无返回,not exists true,对于最外层查询则保留不存在的结果。

 

2.4查找没有职员的部门;

mysql> select d.*

    -> from dept d left join emp e

    -> on(d.deptno = e.deptno)

-> where e.deptno is null;

 

返回一个表中的所有行,以及另一个表中与公共列匹配或者不匹配的行,然后保存不匹配的行。

 

2.5    返回所有员工信息、他们的工作部门地点及所获得的奖励。

Mysql> select ename,loc,received

->from emp e join dept d on(e.deptno = d.deptno)

->left join emp_bonus eb on(e.empno = eb.empno);

 

标量子查询(不会危及到当前结果而获取额外数据的一种简单方法;要求标量子查询返回的是标量值)

mysql> select e.ename,d.loc,

    -> (select received from emp_bonus eb where eb.empno = e.empno)

    -> from emp e,dept d

    -> where e.deptno = d.deptno

-> order by 2;

 

2.6    查找在部门10中所有员工的工资合计和奖金合计。(并不是所有人都有奖金)

 

考虑是否有重复工资的计算,因为奖金表可能有一名员工有两个奖金纪录;

考虑部门里是否有没有奖金的员工,也要算入部门的总工资。

mysql> select deptno,sum(distinct sal) as total_sal,sum(bonus) as total_bonus

    -> from (

    -> select e.deptno,e.sal,e.sal*case

    -> when eb.type is null then 0

    -> when eb.type = 1 then .1

    -> when eb.type = 2 then .2

    -> else .3

    -> end as bonus

    -> from emp e left join emp_bonus eb

    -> on(e.empno = eb.empno)

-> where e.deptno = 10) x;

 

2.7    需要在表EMP中查找出所有比”WARD” 提成(COMM)低的员工,提成为NULL的员工也应包括在其中;

coalesce()函数 [keules]

mysql> select ename,comm, coalesce(comm,0)

    -> from emp

    -> where coalesce(comm,0) < (select comm from emp where ename = 'WARD');

你可能感兴趣的:(《SQL CookBook》 简单查询汇总)