收藏 分享(赏)

实验七练习.doc

上传人:fmgc7290 文档编号:6542390 上传时间:2019-04-16 格式:DOC 页数:5 大小:42.50KB
下载 相关 举报
实验七练习.doc_第1页
第1页 / 共5页
实验七练习.doc_第2页
第2页 / 共5页
实验七练习.doc_第3页
第3页 / 共5页
实验七练习.doc_第4页
第4页 / 共5页
实验七练习.doc_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

1、练习答案:查询雇员表中工资最高的雇员的员工号、员工姓名、工资和部门号。select empno,ename,sal,deptno from empwhere sal = (select max(sal) from emp);单条查询语句综合练习题:薪水大于 1200的雇员,按照部门编号进行分组,分组后的平均薪水必须大于1500,查询各分组的平均工资,按照工资的倒序进行排列。select avg(sal) avg_sal, deptnofrom empwhere sal 1200group by deptnohaving avg_sal 1500order by avg_sal desc;说明:

2、此句基本上包含了 SQL语句的子语句和排列顺序:select(要查询的字段)-from(从哪一张或哪几张表或视图)-where(过滤条件)-group by(having)(分组及条件)-order by(按哪个或哪几个字段进行升序或降序排列) 。注意:SqlServer4.1 中可能不支持在 order语句中使用组函数 avg,报错说:invalid use of group function(错误提示和现象有点对不上)解决办法:给 avg(sal)起个别名 avg_sal,这样在 order语句中就直接使用这个别名等值连接:查询每个雇员和其所在的部门名select ename,dname

3、from emp,dept where (emp.deptno = dept.deptno);或者(推荐)(on 中就写连接条件,where 中就写过滤条件,各司其职)select ename,dname from emp join dept on(emp.deptno = dept.deptno);非等值连接:查询每个雇员姓名及其工资所在的等级select ename,grade from emp e join salgrade s on(e.sal between s.losal and s.hisal);查询雇员名第 2个字母不是 a的雇员的姓名、所在的组名、工资所在的等级。三张表的连接

4、查询(先连接,再加上 where语句进行过滤)select ename,dname,gradefrom emp e join dept d on(e.deptno = d.deptno)join salgrade s on(e.sal between s.losal and s.hisal)where ename not like _a%;查询每个雇员和其经理的姓名自连接:(事实上只有一张表,但把它当成两张表来用,使用别名来进行区分)select e1.ename,e2.ename from emp e1,emp e2 where (e1.mgr = e2.empno);或者:(推荐用 joi

5、n语句)select e1.ename,e2.ename from emp e1 join emp e2 on(e1.mgr = e2.empno);查询每个雇员和其经理的姓名(包括公司老板本身(他上面没有经理) )左外连接(会把左表中不符合连接条件的记录也显示出来):select e1.ename,e2.ename from emp e1 left join emp e2 on(e1.mgr = e2.empno);查询每个雇员的姓名及其所在部门的部门名(包括没有雇员的部门)右外连接(会把右表中不符合连接条件的记录也显示出来):select ename,dname from emp e ri

6、ght join dept d on(e.deptno = d.deptno);子查询 1:查询每个部门中工资最高的人的姓名、薪水和部门编号先求出每个部门中的最高工资:select max(sal) max_sal,deptno from emp group by deptno在使用连接查询:select ename,sal,e.deptnofrom emp e join(select max(sal) max_sal,deptno from emp group by deptno) ton(e.sal = t.max_sal and e.deptno = t.deptno);子查询 2:查询

7、每个部门平均工资所在的等级select deptno,avg_sal,grade from salgradejoin(select deptno,avg(sal) avg_sal from emp group by deptno) ton(t.avg_sal between salgrade.losal and salgrade.hisal);或者:select deptno,avg_sal,grade from(select deptno,avg(sal) avg_sal from emp group by deptno) tjoin salgrade s on(t.avg_sal betw

8、een s.losal and s.hisal);子查询 3:查询每个部门内平均的薪水等级先求每个人的薪水等级select ename,deptno,grade from emp join salgrade s on(emp.sal between s.losal and s.hisal);再按组进行分组求平均select deptno,avg(grade) from(select ename,deptno,grade from emp join salgrade s on(emp.sal between s.losal and s.hisal) tgroup by deptno;子查询 4:

9、查询雇员中有哪些人是经理人:select ename from emp where empno in(select distinct mgr from emp);或者:select ename from emp join(select distinct mgr from emp) ton(emp.empno=t.mgr);子查询 5:不准用库函数,求雇员表中薪水的最高值。思路:两张完全相同的雇员表,左边一张,右边一张。拿左表中的薪水和右表中的薪水进行比较,左表中的最高薪水值必定不可能小于右表中的某一薪水值。先求出 emp表中最高薪水以下的所有薪水值select distinct e1.sal

10、from emp e1 join emp e2 on(e1.sal e2.sal);不在此列的薪水值即为最高薪水值select distinct sal from emp where sal not in(select distinct e1.sal from emp e1 join emp e2 on(e1.sal e2.sal);子查询 6:平均薪水最高的部门的部门编号:先求出每个部门的平均薪水和部门号(把这个看成一张表)select avg(sal) avg_sal,deptno from emp group by deptno;:再求出平均薪水最高值(把这个看成一个值)select m

11、ax(avg_sal) from (select avg(sal) avg_sal,deptno from emp group by deptno) t;:对表使用条件进行查询即可select avg_sal,deptno from(select avg(sal) avg_sal,deptno from emp group by deptno) t1where avg_sal=(select max(avg_sal) from (select avg(sal) avg_sal,deptno from emp group by deptno) t2);说明:在 Oracle中可以使用组函数嵌套来

12、稍微简化 SQL语句的复杂程度(最多是两层嵌套):select max(avg(sal) from emp group by deptno;来求出平均薪水最高值注意:这种组函数嵌套在 MySQL中不可以用子查询 7:求平均薪水最高的部门的部门名称(在子查询 6的基础之上)说明:在实际应用中,达到这种程度的 SQL语句已经算比较复杂了。select dname from dept where deptno = ( select deptno from(select avg(sal) avg_sal,deptno from emp group by deptno) t1where avg_sal=

13、(select max(avg_sal) from (select avg(sal) avg_sal,deptno from emp group by deptno) t2);-子查询 8:查询平均薪水的等级最低的部门名称说明:在实际应用中,很少使用到如此复杂的 SQL语句。但要掌握一步步的思路,本例是为了锻炼逻辑能力。求平均薪水select avg(sal) avg_sal,deptno from emp group by deptno;求平均薪水的等级select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from e

14、mp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal);求平均薪水的等级最低的那个值select min(grade) from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t3;平均薪水的等级最低的部门的部门编号(将和组合起来,将看成要查询的表,将

15、看成查询条件)select deptno from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t2where grade=( select min(grade) from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by dept

16、no) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t3);平均薪水的等级最低的部门名称select dname from dept where deptno=( select deptno from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t2where grade=(

17、select min(grade) from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t3);或者:还有种思路,使用 join连接多张表(效果同上面的和,但比上面的稍微简单些)查询平均薪水的等级最低的部门的部门名、部门编号、平均工资和等级(将和组合起来,将和 dept表 join起来,将看成查询条件)select dname,t2.deptn

18、o,avg_sal,grade from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t2join dept on(t2.deptno=dept.deptno)where t2.grade=( select min(grade) from( select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal) t3);说明:本例中有个待改进的地方,就是有重复的语句段(出现了两次):select avg_sal,deptno,grade from(select avg(sal) avg_sal,deptno from emp group by deptno) tjoin salgrade s on(t.avg_sal between s.losal and hisal)

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 中等教育 > 中学实验

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报