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. swoole简介

    swoole是PHP的扩展,又不是一个普通的扩展.普通的扩展只是提供一个库函数.而swoole扩展在运行后会接管PHP的控制权,进入事件循环.当IO事件发生后,swoole会自动回调指定的PHP函数. ...

  2. UML简单介绍—类图这么看就懂了

    如何看懂类图 1.类图简介 描述类的内部结构和类与类之间的关系,是一种静态结构图. 在UML类图中,常见的有以下几种关系: 泛化(Generalization),  实现(Realization),关 ...

  3. MS SQL 批量操作

    MS SQL支持 sysobject,因此可以用以下条件语句查询表对象 select Name from sysobjects where xtype='U' and Name like 'dnt_% ...

  4. Fiddler之模拟响应、修改请求或响应数据(断点)

    在测试过程中,有时候需要修改请求或响应数据,或者直接模拟服务器响应,此时可以使用fiddler进行此类操作.可以使用断点功能完成. 一.修改请求数据 在发起请求后,需要修改请求的数据时,可以设置请求前 ...

  5. [译]Vulkan教程(25)描述符布局和buffer

    [译]Vulkan教程(25)描述符布局和buffer Descriptor layout and buffer 描述符布局和buffer Introduction 入门 We're now able ...

  6. 【学习笔记】C/C++

    1. C语言中的 scanf() 函数 该函数包含在头文件 <stdio.h> 或者 <cstdio> (在C++中使用时) 函数的返回值指的是 所输入的数据与格式字符串匹配的 ...

  7. new String()与toString

    str.toString是调用了str这个object对象的类的toString方法.一般是返回这么一个String:[class name]@[hashCode].new String(str)是根 ...

  8. Java题库——chapter7 多维数组

    1)Which of the following statements are correct? 1) _______ A)char[ ][ ] charArray = {{'a', 'b'}, {' ...

  9. [Spring cloud 一步步实现广告系统] 11. 使用Feign实现微服务调用

    上一节我们使用了Ribbon(基于Http/Tcp)进行微服务的调用,Ribbon的调用比较简单,通过Ribbon组件对请求的服务进行拦截,通过Eureka Server 获取到服务实例的IP:Por ...

  10. Web前端基础(10):JavaScript(四)

    1. 伪数组arguments arguments代表的是实参.有个讲究的地方是:arguments只在函数中使用. 1.1 返回参数个数 返回函数实参的个数:arguments.length 例子: ...