mysql 经典练习题上
MY SQL
三张表
emp 表, 字段empno, ename, job, mgr, hiredate, sal, comm, deptno
dept表 , 字段 deptno, dname, loc
salgrade, 字段 grade, losal, hisal
第一题, 列出至少有五个员工的所有部门
- 先求出每个部门的员工数量
- 再加条件
# 先求每个部门的员工数量
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
第二题,列出受雇日期早于其上级的员工编号,姓名,部门名称
- 核心方法是一张表多用,员工的领导编号是领导的员工编号,就可以人为的造出两张表格
- 然后用条件判断大于领导编号
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
第三题, 取得每个薪水等级共有多少个员工
- 先求出员工的薪水等级
- 把员工的薪水等级作为一个临时表,对这个临时表进行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 经典练习题上的更多相关文章
- MYSQL经典练习题,熟悉DQL
MYSQL经典练习题 (本练习题可让你熟悉DQL,快速的上手DQL) 首先,先在数据库中建立基本数据库以及表项: DROP DATABASE IF EXISTS `test`; CREATE DATA ...
- MySQL经典练习题
表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id ...
- MySQL经典练习题及答案,常用SQL语句练习50题
表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id,c_name,t_id ...
- 10 个 MySQL 经典错误【转】
Top 1:Too many connections(连接数过多,导致连接不上数据库,业务无法正常进行) 问题还原 mysql> show variables like '%max_connec ...
- 【Python全栈-后端开发】MySQL数据库-练习题
MySQL数据库-练习题 一.表关系 请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号: 3.查询平均成绩大于60分的同学的学号 ...
- 【不断更新】mysql经典50道题自我练习
mysql经典50道题自我练习 测试数据和练习题均转载自CSDN博主@启明星的指引的文章sql语句练习50题(Mysql版),用于mysql的每日自我练习 表名和字段 –1.学生表 Student(s ...
- Angularjs+node+Mysql实现地图上特定点的定位以及附加信息展示
注:本博文为博主原创,转载请注明出处. 在上一篇博文中主要讲述了如何利用AngularJs+Node+MySql构建项目,并实现地图上的多点标注,今天在这篇文章中,我们将在上一个项目的基础上,实现特定 ...
- 远程连接MySql连不上1130
mysql数据库user表中已存在主机=%的用户root,连接却提示1130. 用navicat开启user表>>>>在表里直接修改%账户root的密码(看到是未加密过的内容) ...
- 4月数据库流行度排行榜 MySQL能否追上Oracle
4月的数据库流行度排行榜可谓看点十足.闲言少叙,先上图: 前十名中,名次上升的都是NoSQL数据库,NoSQL凭借其对大数据处理的优势,发展越来越快.NoSQL是对众多非传统关系型数据库的总称,按存储 ...
随机推荐
- swoole简介
swoole是PHP的扩展,又不是一个普通的扩展.普通的扩展只是提供一个库函数.而swoole扩展在运行后会接管PHP的控制权,进入事件循环.当IO事件发生后,swoole会自动回调指定的PHP函数. ...
- UML简单介绍—类图这么看就懂了
如何看懂类图 1.类图简介 描述类的内部结构和类与类之间的关系,是一种静态结构图. 在UML类图中,常见的有以下几种关系: 泛化(Generalization), 实现(Realization),关 ...
- MS SQL 批量操作
MS SQL支持 sysobject,因此可以用以下条件语句查询表对象 select Name from sysobjects where xtype='U' and Name like 'dnt_% ...
- Fiddler之模拟响应、修改请求或响应数据(断点)
在测试过程中,有时候需要修改请求或响应数据,或者直接模拟服务器响应,此时可以使用fiddler进行此类操作.可以使用断点功能完成. 一.修改请求数据 在发起请求后,需要修改请求的数据时,可以设置请求前 ...
- [译]Vulkan教程(25)描述符布局和buffer
[译]Vulkan教程(25)描述符布局和buffer Descriptor layout and buffer 描述符布局和buffer Introduction 入门 We're now able ...
- 【学习笔记】C/C++
1. C语言中的 scanf() 函数 该函数包含在头文件 <stdio.h> 或者 <cstdio> (在C++中使用时) 函数的返回值指的是 所输入的数据与格式字符串匹配的 ...
- new String()与toString
str.toString是调用了str这个object对象的类的toString方法.一般是返回这么一个String:[class name]@[hashCode].new String(str)是根 ...
- Java题库——chapter7 多维数组
1)Which of the following statements are correct? 1) _______ A)char[ ][ ] charArray = {{'a', 'b'}, {' ...
- [Spring cloud 一步步实现广告系统] 11. 使用Feign实现微服务调用
上一节我们使用了Ribbon(基于Http/Tcp)进行微服务的调用,Ribbon的调用比较简单,通过Ribbon组件对请求的服务进行拦截,通过Eureka Server 获取到服务实例的IP:Por ...
- Web前端基础(10):JavaScript(四)
1. 伪数组arguments arguments代表的是实参.有个讲究的地方是:arguments只在函数中使用. 1.1 返回参数个数 返回函数实参的个数:arguments.length 例子: ...