04 多表查询 分组查询(1)
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Select job,count(*),min(sal) from emp group by job having min(sal)>1500; 13. 列出在部门 SALES(销售部)工作的员工的姓名,假定不知道销售部的部门编号。 Select e.name,dname from emp e,dept d where e.deptno=d.deptno and dname=’SALES’; 14. 列出薪金高于公司平均薪金的所有员工,所在部门,上级领导,公司的等级工资。 sele 15. 列出与 SCOTT 从事相同工作的所有员工的编号,姓名,职位及其部门名称。
算在内。 31. 查询所有部门的名字 dname,所在位置 loc,员工数量和工资平均值。
从大到小排序。 select deptno,avg(sal) from emp group by deptno having avg(sal)>=2000 order by avg(sal); 5. 查询 emp 表中出部门合计薪水大于等于 1000 的部门的部门代码、平均薪水,并按平均薪水
从大到小排序。 select deptno,avg(sal),sum(sal) from emp group by deptno having sum(sal)>=1000 order by avg(sal);
第 1 章 多表查询
1. 显示所有员工的姓名 ename,部门号 deptno 和部门名称 dname。 select ename,emp.deptno,dname from emp,dept where emp.deptno=dept.deptno; 2. 查询 20 号部门员工的 job 和 20 号部门的 loc。 select job,loc from emp,dept where emp.deptno=dept.deptno; 3. 选择所有有奖金 comm 的员工的 ename , dname , loc。 select ename,dname,loc from emp join dept using (deptno) where comm is not null; 4. 选择在工作地点 DALLAS 工作的员工的 ename , job , deptno, dname。 select ename,dname,loc from emp join dept using (deptno) where loc='DALLAS'; 5. 选择所有员工的姓名 ename,员工号 empno,以及他的管理者 mgr 的姓名 ename 和员工号 empno,
结果类似于下面的格式:
employees
Emp#
manager
Mgr#
SMITH
7369
FORD
7902
Fra Baidu bibliotek
select e.ename employees,e.empno Emp#,m.ename manager,e.mgr Mgr# from emp e,emp m where e.mgr=m.empno; 6. 查询各部门员工姓名和他们所在位置,结果类似于下面的格式:
16. 列出薪金等于部门 30 中员工的薪金的,所有员工的姓名和薪金。 17. 列出薪金高于在部门 30 工作的所有员工的薪金的员工姓名、薪金和部门名称。 18. 列出在每个部门工作的员工数量、平均工资和平均服务期限。 19. 列出所有员工的姓名、部门名称和工资。 20. 列出所有部门的详细信息和部门人数。 21. 列出各种工作的最低工资及从事此工作的雇员姓名。 22. 列出各个部门的 MANAGER(经理)的最低薪金。 23. 列出员工的年工资,按年薪从低到高排序。 24. 查出员工的信息,并要求这些员工的主管的薪水超过 3000。 25. 求出部门名称中,带 S 字符的部门员工的、工资合计、部门人数。 26. 查询公司员工工资的最大值,最小值,平均值,总和。 27. 查询各 job 的员工工资的最大值,最小值,平均值,总和。 28. 选择具有各个 job 的员工人数(提示:对 job 进行分组)。 29. 查询员工最高工资和最低工资的差距。 30. 查询各个管理者手下员工的最低工资,其中最低工资不能低于 800,没有管理者的员工不计
9. 显示:员工编号,员工名称,经理编号,经理名称,员工所在部门编号,员工所在部门名称, 经理所在部门编号,经理所在部门名称。
第 2 章 分组查询
1. 列出至少有一个员工的所有部门。 Select deptno,count(*) from emp group by deptno having count(*)>=1; 2. 查询 emp 表中出每个部门的部门代码、薪水之和、平均薪水。 select deptno,sum(sal),avg(sal) from emp group by deptno; 3. 查询 emp 表中出部门人数大于等于 2 的部门的部门代码、部门人数。 select deptno,count(*) from emp group by deptno having count(*)>=2; 4. 查询 emp 表中出部门平均薪水小于等于 2000 的部门的部门代码、平均薪水,并按平均薪水
6. 查询 emp 表中薪水最少,和薪水最大员工的姓名和薪水,并按薪水从大到小排序。
7. 列出薪金比 SMITH 高的所有员工。 select ename,sal from emp where sal>=(select sal from emp where ename='SMITH'); 8. 列出所有员工的姓名及其直接上级领导的姓名。 Select e.ename,m.ename from emp e,emp m where e.mgr=m.empno 9. 列出受雇日期早于其直接上级的所有员工的编号,姓名,部门名称。 Select e.empno,e.ename,dname from emp e,emp m,dept where e.mgr=m.empno and e.empno=dept.deptno and e.hiredate>m.heredate; 10. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。 Select dname,ename from emp e,dept d where e.empno (+)=d.deptno 11. 列出所有 CLERK(办事员)的部门名称,部门人数。 Select dname,count(*) from dept where 12. 列出最低薪金大于 1500 的各种工作及从事此工作的全部雇员人数。
Deptno
Ename
Loc
20
SMITH
DALLAS
select initcap(deptno),initcap(ename),initcap(loc) from emp join dept using (deptno); 6. 显示:员工编号,员工名称,员工所在部门编号,员工所在部门名称。 select empno,ename,deptno,dname from emp join dept using (deptno); 7. 显示:员工编号,员工名称,经理编号,经理名称。 select e.empno,e.ename,e.mgr,m.ename from emp e,emp m where e.mgr=m.empno; 8. 显示:员工编号,员工名称,经理编号,经理名称,员工所在部门编号,员工所在部门名称。