MY SQL

三张表

emp 表, 字段empno, ename, job, mgr, hiredate, sal, comm, deptno

dept表 , 字段 deptno, dname, loc

salgrade, 字段 grade, losal, hisal

第一题, 列出至少有五个员工的所有部门

  1. 先求出每个部门的员工数量
  2. 再加条件
# 先求每个部门的员工数量
select d.dname, count(e.empno)
e.deptno, count(e.empno) as sum_emp
from
emp e
group by e.deptno # 然后就可以按照要求来进行连接和条件判断
select from
emp e join dept d on e.deptno = d.deptno
group by e.deptno
having count(e.empno) >5

第二题,列出受雇日期早于其上级的员工编号,姓名,部门名称

  1. 核心方法是一张表多用,员工的领导编号是领导的员工编号,就可以人为的造出两张表格
  2. 然后用条件判断大于领导编号
select
e.empno, e.ename, e.deptno, d.dname
from
emp e join emp c
on
e.mgr = d.empno
join dept d
on
e.deptno = d.deptno
where
e.hiredate < d.hiredate

第三题, 取得每个薪水等级共有多少个员工

  1. 先求出员工的薪水等级
  2. 把员工的薪水等级作为一个临时表,对这个临时表进行group by 和计数操作
select
t.grade, count(t.ename)
from
(select
e.ename, s.grade
FROM
emp e join salgrade s
on
e.sal between s.losal and s.hisal) t
group by t.grade;

第四题, 取得比普通员工的薪水还要高的经理人的姓名

 1.1 先找出普通员工
-- 1.1.1 先找出经理人编号
SELECT distinct mgr from emp;
-- 1.1.2 员工编号不在经理人编号里的就是员工编号
select * from emp where empno not in
(SELECT distinct mgr from emp where mgr is not null);
-- 1.2 查找出普通员工的最大薪资
select max(sal) as max_sal from emp where empno not in
(SELECT distinct mgr from emp where mgr is not null);
-- 1.3 员工表中大于员工薪资的就是经理, 因为大于最大员工就一定是经理
select
ename
from
emp
where
sal > (select max(sal) as max_sal from emp where empno not in
(SELECT distinct mgr from emp where mgr is not null));

第五题, 求平均薪水等级最低的部门编号

-- 1.1 求每个部门平均薪水等级情况
select
e.deptno, s.grade as avg_grade
from
emp e inner join salgrade s
on
e.sal between s.losal and s.hisal
group by e.deptno;
-- 1.2 求出部门最低薪水等级
select
min(t.avg_grade)
from
(select
e.deptno, s.grade as avg_grade
from
emp e inner join salgrade s
on
e.sal between s.losal and s.hisal
group by e.deptno) t; -- 1.3 将两张表格进行连接 having 作为条件 grade
select
e.deptno, s.grade as avg_grade
from
emp e inner join salgrade s
on
e.sal between s.losal and s.hisal
group by e.deptno
having avg_grade = (select
min(t.avg_grade)
from
(select
e.deptno, s.grade as avg_grade
from
emp e inner join salgrade s
on
e.sal between s.losal and s.hisal
group by e.deptno) t);

第六题,求出平均薪水最高的部门编号

-- 1.1 求出每个部门的平均薪资
select
deptno, avg(sal) avg_sal
from
emp
group by deptno; -- 1.2 求出最高的平均薪资
select
max(avg_sal)
from
(select
deptno, avg(sal) avg_sal
from
emp
group by deptno) t; -- 1.3 求出平均薪水对应的最高编号
select
deptno, avg(sal) avg_sal
from
emp
group by deptno
having avg_sal = (select
max(avg_sal)
from
(select
deptno, avg(sal) avg_sal
from
emp
group by deptno) t);

第七题, 求出部门中所有人的平均薪水等级

-- 1.1 每个部门的平均薪水
select
deptno, avg(sal) avg_sal
from
emp
group by deptno;
-- 1.2 每个部门对应的薪水等级
select
t.deptno, s.grade
from
(select
deptno, avg(sal) avg_sal
from
emp
group by deptno) t join salgrade s
on t.avg_sal between s.losal and s.hisal;

第八题, 每个部门的最高薪水

-- 1.1 求出每个部门的最高薪资
select
deptno,max(sal) as max_sal
from
emp
group by deptno; -- 1.2 将两张表格进行连接,求出一些想要的东西
select
e.deptno, e.ename, t.max_sal
from
emp e join (select
deptno,max(sal) as max_sal
from
emp
group by deptno) t on e.deptno = t.deptno and e.sal = t.max_sal;

第九题, 哪些人的薪资水平在部门的平平均薪资之上

-- 每个部门平均薪资水平
select
deptno, avg(sal) as avg_sal
from
emp
group by deptno; -- 高于平均薪资的人
select
e.ename, e.sal
from
emp e join (select
deptno, avg(sal) as avg_sal
from
emp
group by deptno) t on e.deptno = t.deptno and e.sal > t.avg_sal;

mysql 经典练习题上的更多相关文章

  1. MYSQL经典练习题,熟悉DQL

    MYSQL经典练习题 (本练习题可让你熟悉DQL,快速的上手DQL) 首先,先在数据库中建立基本数据库以及表项: DROP DATABASE IF EXISTS `test`; CREATE DATA ...

  2. MySQL经典练习题

    表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id ...

  3. MySQL经典练习题及答案,常用SQL语句练习50题

    表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id ...

  4. 10 个 MySQL 经典错误【转】

    Top 1:Too many connections(连接数过多,导致连接不上数据库,业务无法正常进行) 问题还原 mysql> show variables like '%max_connec ...

  5. 【Python全栈-后端开发】MySQL数据库-练习题

    MySQL数据库-练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 3.查询平均成绩大于60分的同学的学号 ...

  6. 【不断更新】mysql经典50道题自我练习

    mysql经典50道题自我练习 测试数据和练习题均转载自CSDN博主@启明星的指引的文章sql语句练习50题(Mysql版),用于mysql的每日自我练习 表名和字段 –1.学生表 Student(s ...

  7. Angularjs+node+Mysql实现地图上特定点的定位以及附加信息展示

    注:本博文为博主原创,转载请注明出处. 在上一篇博文中主要讲述了如何利用AngularJs+Node+MySql构建项目,并实现地图上的多点标注,今天在这篇文章中,我们将在上一个项目的基础上,实现特定 ...

  8. 远程连接MySql连不上1130

    mysql数据库user表中已存在主机=%的用户root,连接却提示1130. 用navicat开启user表>>>>在表里直接修改%账户root的密码(看到是未加密过的内容) ...

  9. 4月数据库流行度排行榜 MySQL能否追上Oracle

    4月的数据库流行度排行榜可谓看点十足.闲言少叙,先上图: 前十名中,名次上升的都是NoSQL数据库,NoSQL凭借其对大数据处理的优势,发展越来越快.NoSQL是对众多非传统关系型数据库的总称,按存储 ...

随机推荐

  1. sudo go 找不到命令

    我们使用 sudo 时,使用的配置文件是 /etc/sudoers. 解决配置 /etc/sudoers 文件中的 Defaults secure_path 这一项.将 $GOROOT/bin 目录加 ...

  2. nltk的安装和简单使用

    使用python进行自然语言处理,有一些第三方库供大家使用: ·NLTK(Python自然语言工具包)用于诸如标记化.词形还原.词干化.解析.POS标注等任务.该库具有几乎所有NLP任务的工具. ·S ...

  3. Vue和React的区别,以及如何选择?

    简介 React:React是一个用于创建可重用且有吸引力的UI组件的库.它非常适合代表经常变化的数据的组件. Vue:Vue.js是一个开源JavaScript框架,能够开发单页面应用程序.它还可以 ...

  4. SQL索引碎片的产生,处理过程。

    本文参考 https://www.cnblogs.com/CareySon/archive/2011/12/22/2297568.html https://www.jb51.net/softjc/12 ...

  5. Oracle通过SQL语句查看table所引用的对象(View/Function/Procedure/Trigger)

    通过使用user_dependencies进行查看,如下: SELECT * FROM user_dependencies WHERE referenced_name='SFCUSN' --Table ...

  6. 通过BGP实现流量劫持

    BGP BGP全称是Border Gateway Protocol,翻译成中文是边界网关协议,用于全球各个AS之间的路由.它的地位是毋庸置疑的,如果没有它就没有全球的因特网.因为全球各个AS都等价的维 ...

  7. 《工作笔记:移动web页面前端开发总结》

    工作笔记:移动web页面前端开发总结 移动web在当今的发展速度是一日千里,作为移动领域的门外汉,在这段时间的接触后,发现前端开发这一块做一个小小的总结. 1.四大浏览器内核 1.Trident (I ...

  8. shell中字典的一个用法示例

    1. shell中字典的用法示例, 数组用法同字典 2. 以上使用sell配合字典实现的功能, 使用awk能轻松搞定, 如下: awk '{print $2}' file.txt | sort | u ...

  9. PHP如何开启swoole扩展

    swoole是一个PHP的异步.并行.高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis,数据库连接池,AsyncT ...

  10. jQuery-文件上传问题解决

    后端要求文件上传需传参数为二进制流,用form-data方式传递,如下图所示: 为了满足该输入参数要求,上传代码如下: <input type="file" id=" ...