老杜MySql——34道作业题
老杜MySql链接:https://www.bilibili.com/video/BV1Vy4y1z7EX?p=132
本次随笔主要来源于老杜MySql讲解视频后面的作业题,加上个人的一些理解,以及整理;
部分较为简单就不进行收录了;
基本表的相关信息,以及部分实例数据:
emp



1.取得每个部门最高薪水的人员名称
(1)首先找到每个部门最高的薪水
select deptno,max(SAL) maxsal
from emp
group by deptno;
(2)将上述查询结果作为一个新表t,进行连接查询找出相关名字
select ename
from emp e
join t
on e.sal=t.sal and e.deptno=t.deptno;
最终结果为:
select ename
from emp e
join (select DEPTNO,max(SAL) maxsal from EMP group by DEPTNO )t
on e.sal=t.sal and e.deptno=t.deptno;
2.哪些人的薪水在部门的平均的水平之上
(1)先找出每个部门的工资平均水平
select deptno,avg(asl) avgsal
from emp
group by deptno;
(2)与1同理
select ename
from emp e
join (select deptno,avg(SAL) avgsal from emp group by deptno )t
on e.sal>t.avgsal and e.deptno=t.deptno;
需要注意点:连接条件中的t.avgsal,即采用了重命名的方式不可轻易修改,如果直接使用函数则会出错
3.取得部门所有人平均的薪资等级
(1)查出每个人薪水等级
select empno,grade
from emp e,aslgrade s
where e.sal between s.loasl and s.hisal;
(2)将查出的结果再次求平均
selece avg(t.grade) avggrade
from (select empno,grade
from emp e,aslgrade s
where e.sal between s.loasl and s.hisal) t
3.1取得部门所有人平均薪水的等级
(1)取得所有人的平均薪水
select deptno,avg(asl) avgsal
from emp;
(2)根据薪水确定等级
select grade
from (select deptno,avg(asl) avgsal from emp) t,salgrade s
where avg between s.logal and hisal;
4.不准用组函数(max),取得最高薪水(两种方法)
方法1:排序
select sal
from emp
order by sal desc
limit 1;
方法2:表连接
思路:首先找出出了最高薪水以外其他的薪水()
select distinct e1.sal
from
emp e1
join
emp e2
on e1.sal<e2.sal;
(2)将上述结果排除
select sal
from emp
where sal not in(
select distinct e1.sal
from
emp e1
join
emp e2
on e1.sal<e2.sal;
)
5.取得平均薪资最高的部门的部门编号(至少给出两种解决方案)
(1)求每个部门的平均薪资
select e.deptno,avg(sal) avgsal
from emp e
group by e.deptno;
(2)
select deptno,max(avgsal)
from (
select e.deptno,avg(sal) avgsal
from emp e
group by e.deptno;
)
其他方法为取最大值的部分使用order by desc limit 1;
官方做法:
select e.deptno,avg(sal) avgsal
from emp e
group by e.deptno
order by avgsal
limit 1;
其二:

6.取得平均薪资最高的部门的部门名称
同上
7.求平均薪水等级最低的部门名称
在此基础上加上连接
8.取得比普通员工(员工代码没有在mgr字段上出现的)的最高薪水还要高的领导人姓名
(0)出现在mgr字段上的代码
select distinct mgr
from emp;
(1)求出普通员工的最高薪资水平
select max(sal)
from emo e
where empno not in(select distinct mgr
from emp where mgr is not null);
关键点在于需要派除null 的存在,有null存在则所有的值变为null
(2)最终求解
select sal
from emp
where sal>(
select
max(sal)
from
emo e
where
empno not in(select distinct mgr from emp where mgr is not null)
);
9.列出每个部门工作的员工数量,平均工资和平均服务期限
select d.deptno,count(e.ename),ifnull(avg(e.sal),0),avg(timestampdiff(YEAR,hiredate,now()))
from
emp e
right join
dept d
on
e.deptno=d.deptno
group by
d.deptno;
关键点 :计算日期之间差值的函数timestampdiff(YEAR,hiredate,now())
YEAR:间隔类型 hiredate:开始日期 now():结束日期
间隔类型的其他值:second 秒 minute 分钟 hour 小时 day天
week 星期 month 月 quarter季度
老杜MySql——34道作业题的更多相关文章
- 老杜告诉你java小白到大神是怎么炼成的(转载)
老杜告诉你java小白到大神是怎么炼成的 1. 学习前的准备 一个好的学习方法(应该怎么学习更高效): 一个合格的程序员应该具备两个能力 有一个很好的指法速度(敲代码快) 有一个很好的编程思想(编程思 ...
- 动力节点 mysql 郭鑫 34道经典的面试题三
1.第十五题 15.列出受雇日期早于其直接上级的所有员工编号.姓名.部门名称 思路一:第一步将emp a看成员工表,将emp b 看成领导表,员工表的mgr字段应该等于领导表的主键字段 mysql&g ...
- 动力节点 mysql 郭鑫 34道经典的面试题二
13.有3个表S(学生表),C(课程表),SC(学生选课表) S(SNO,SNAME)代表(学号,姓名) C(CNO,CNAME,CTEACHER)代表(课号,课名,教师) SC(SNO,CNO,SC ...
- 动力节点 mysql 郭鑫 34道经典的面试题
DROP TABLE IF EXISTS `dept`; CREATE TABLE `dept` ( `DEPTNO` int(2) NOT NULL COMMENT '部门编号', `DNAME` ...
- MYSQL 45道练习题
学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表(一)~表(四)所示.用S ...
- 34、mysql数据库(介绍)
34.1.什么是数据库: 数据库(database,DB)是指长期存储在计算机内的,有组织,可共享的数据的集合.数据库中的数据按一定的数学模型组织. 描述和存储,具有较小的冗余,较高的数据独立性和易扩 ...
- MySQL优化|一分钟带你了解单表优化
在开始前,分享给大家我看过觉得讲数据库讲的算是很不错的,也在B站拥有百万播放量的教程. 这个MySQL视频是动力节点的老杜讲解,个人也很喜欢老杜的教学风格,老杜真的是从MySQL基础一点点带我入门,基 ...
- 操作笔记:linux下安装mysql
1,检查linux下是否安装了mysql shell指令如下: [root@iZ945sgm0ugZ ~]# rpm -qa|grep -i mysql 如果有的话:做出挨个删除(eg:rpm -ev ...
- sqldeveloper连接mysql
sqldeveloper连接mysql 腑镜诏 钌d 汁叁ㄧ勋 佚蔡弥噙 不仅仅是越南帮和戴爷的事情还有谢婉莹的条 炔验遒其 倒扇油┣ 砹笄谤 几句话孟飞的信心大增兴奋不已换句话说 谠诂k厝 ...
随机推荐
- C#Lambda表达式演变和Linq的深度解析
Lambda 一.Lambda的演变 Lambda的演变,从下面的类中可以看出,.Net Framwork1.0时还是用方法实例化委托的,2.0的时候出现了匿名方法,3.0的时候出现了Lambda. ...
- linux常见命令chgrp/chown/chmod
linux文件权限有读(r-4)写(w-2)执行(x-1) linux文件的所有方式有拥有者(user),属组(group),其他人(others) 改变文件属组命令 -- chgrp 修改/data ...
- Python 元类详解
一.Type介绍 在Python中一切皆对象,类它也是对象,而元类其实就是用来创建类的对象(由于一切皆对象,所以元类其实也是一个对象). 先来看这几个例子: 例1: In [1]: type(12) ...
- .NET 跨平台应用开发动手教程 |用 Uno Platform 构建一个 Kanban-style Todo App
作者:Steven Giesel 翻译:Alan Wang 校对:李卫涵 – 微软 MVP 排版:Rani Sun 有什么比参考包含分步说明和代码示例的动手教程更好的学习新技术的方式呢?当你完成或 f ...
- 二位数组——扩展:冒泡排序、Arrays类
1.冒泡排序 速记口诀(升序) n个数字来排队:两两相比小靠前:外层循环n-1:内层循环n-i-1. 示例:定义一个数组,用冒泡排序将数组进行升序排序 关键代码: 输出结果: 2.Arrays 类 ...
- 项目应用丨Modbus转Profinet网关连接ABB变频器的现场应用记录
本案例客户需求是将ABB变频器接入到Profinet网络中,使用设备为西门子1200PLC,ABB变频器以及小疆智控Modbus转profinet网关.1.首先打开西门子组态软件,新建一个项目. 2. ...
- 面试突击72:输入URL之后会执行什么流程?
在浏览器中输入 URL 之后,它会执行以下几个流程: 执行 DNS 域名解析: 封装 HTTP 请求数据包: 封装 TCP 请求数据包: 建立 TCP 连接(3 次握手): 参数从客户端传递到服务器端 ...
- Jenkins使用pipeline部署服务到远程服务器
写这篇文章是对之前搭建Jenkins做的修改和完善,让jenkins更好的为我们服务 Docker搭建Jenkins服务 使用过程中遇到的问题: 为方便部署,打算将jenkins用到的jdk11.ma ...
- nmtui 字符界面图形模式配置
一.通过nmtui配置网络参数 Linux系统配置网络参数的方式有很多种,其中最简单最直接的方式就是直接修改网卡配置文件,但这种方式也很容易出错,比如说IPADDR.NETMASK.GATEWAY等参 ...
- React中useMemo与useCallback的区别
useMemo 把"创建"函数和依赖项数组作为参数传⼊入useMemo,它仅会在某个依赖项改变时才重新计算memoized 值.这种优化有助于避免在每次渲染时都进⾏行行⾼高开销的计 ...