Mysql案例4:要求查询平均薪水最高部门的部门编号

一、要求:查询平均薪水最高部门的部门编号

二、背景:emplyee表数据如下

三、难点:需要考虑最高平均薪资可能在多个部门同时出现,查询出来的结果需要涵盖所有最高平均薪资的部门id

四、思路:

第一步:先求出每个部门的平均薪资,作为临时表 t

SELECT departmentid,AVG(salary) avgsal
FROM employee
GROUP BY departmentid

第二步:从第一步得出的每个部门平均薪资里求出最高值

SELECT
            MAX(t.avgsal) maxsal
FROM (
            SELECT departmentid,AVG(salary) avgsal
            FROM employee
            GROUP BY departmentid) t

第三步:用 临时表 t 再去匹配第二步得出的最大值,看哪个部门的平均薪资等于第二步的值

最终代码:

SELECT
            e.departmentid,AVG(e.salary) avgsal
FROM
            employee e
GROUP BY
            departmentid
HAVING
            avgsal = (
                                SELECT
                                            MAX(t.avgsal) maxsal
                                FROM (
                                            SELECT departmentid,AVG(salary) avgsal
                                            FROM employee
                                            GROUP BY departmentid) t
                                )

结果图:

原文地址:https://www.cnblogs.com/wodexk/p/10703850.html

时间: 2024-10-09 23:41:47

Mysql案例4:要求查询平均薪水最高部门的部门编号的相关文章

Mysql案例5:取得平均薪资最高的部门的部门名称

一.要求:查询平均薪水最高部门的部门编号 二.背景:当前数据库有employee表和department表,数据分别如下:   employee表:  department表: 三.难点: 1.需要考虑最高平均薪资可能在多个部门同时出现,查询出来的结果需要涵盖所有最高平均薪资的部门id 2.部门名称和员工工资不在一个表,所以需要用连接进行查询获取部门名称 四.SQL语句 SELECT e.departmentid,d.name,AVG(e.salary) avgsal FROM employee

MySQL 之 单表查询

一.简单查询 -- 创建表DROP TABLE IF EXISTS `person`;CREATE TABLE `person` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `age` tinyint(4) DEFAULT '0', `sex` enum('男','女','人妖') NOT NULL DEFAULT '人妖', `salary` decimal(10,2) NOT NULL DEFAUL

最全MySQL数据库表的查询操作

序言 1.MySQL表操作(创建表,查询表结构,更改表字段等), 2.MySQL的数据类型(CHAR.VARCHAR.BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大家不熟悉的就对于INNER JOIN(内连接).LEFT JOIN(左连接).RIGHT JOIN(右连接)等一些复杂查询. 通过本节的学习,可以让你知道这些基本的复杂查询是怎么实现的,但是建议还是需要多动手去敲,虽然理解了什么是内连接等,但是从理解到学会,是完全不一样的感觉. --WZY 一.单表查询 1.1.

MySQL之多表查询

阅读目录 一 多表联合查询 二 多表连接查询 三 复杂条件多表查询 四 子语句查询 五 其他方式查询 六 SQL逻辑查询语句执行顺序(重点) 七 外键约束 八 其他约束类型 九 表与表之间的关系 一.多表联合查询 #创建部门 CREATE TABLE IF NOT EXISTS dept ( did int not null auto_increment PRIMARY KEY, dname VARCHAR(50) not null COMMENT '部门名称' )ENGINE=INNODB D

【MySQL】单表查询 -- 2019-08-11 19:25:09

原文: http://106.13.73.98/__/25/ 目录 where 约束 group by 分组查询 聚合函数 having 过滤 order by 查询排序 limit 限制查询的记录数 # 语法 select 字段1, 字段2 ... from 表名 where 条件 group by field having 筛选 order by field limit 限制条数 重点在于关键字的执行优先级:from where group by having select distinct

【MySQL】单表查询

" 目录 where 约束 group by 分组查询 聚合函数 having 过滤 order by 查询排序 limit 限制查询的记录数 # 语法 select 字段1, 字段2 ... from 表名 where 条件 group by field having 筛选 order by field limit 限制条数 重点在于关键字的执行优先级:from where group by having select distinct order by limit 1. 找到表:from 2

mysql 之多表查询

阅读目录 一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习 一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都会建一个数据库,那数据库里面是不是存了好多张表啊,不可能把所有的数据都放到一张表里面,肯定要分表来存数据,这样节省空间,数据的组织结构更清晰,解耦和程度更高,但是这些表本质上是不是还是一个整体啊,是一个项目所有的数据,那既然分表存了,就要涉及到多个表连接查询了,比如说员工信息一张表,部门信息一张表,那如果我想让你帮我查一下技

【MySQL案例】error.log的Warning:If a crash happens thisconfiguration does not guarantee that the relay lo

1.1.1. If a crash happens thisconfiguration does not guarantee that the relay log info will be consistent [环境描述] msyql5.6.14 [报错信息] mysql的slave启动时,error.log中出现Warning警告: [Warning] Slave SQL: If a crash happensthis configuration does not guarantee tha

MySQL中IN子查询会导致无法使用索引

原文:MySQL中IN子查询会导致无法使用索引 今天看到一个博客园的一篇关于MySQL的IN子查询优化的案例,一开始感觉有点半信半疑(如果是换做在SQL Server中,这种情况是绝对不可能的,后面会做一个简单的测试.)随后动手按照他说的做了一个表来测试验证,发现MySQL的IN子查询做的不好,确实会导致无法使用索引的情况(IN子查询无法使用所以,场景是MySQL,截止的版本是5.7.18) MySQL的测试环境 测试表如下 create table test_table2 ( id int a