前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL练习笔记一:部门员工最高工资

SQL练习笔记一:部门员工最高工资

作者头像
用户6184845
发布2021-01-04 12:50:33
7700
发布2021-01-04 12:50:33
举报

创建Employee 表,包含所有员工信息,每个员工有其对应的 Id, salary 和 department Id。

代码语言:javascript
复制
-- 创建Employee表 --
CREATE TABLE Employee(
  Id int(4) not null,
  Name VARCHAR(10) not null,
  Salary int(10) not null,
  DepartmentId int(4) not NULL
);

-- 增加4条数据 --
INSERT INTO Employee VALUES(1,'Joe',70000,1);
INSERT INTO Employee VALUES(2,'Henry',80000,2);
INSERT INTO Employee VALUES(3,'Sam',60000,2);
INSERT INTO Employee VALUES(4,'Max',90000,1);

创建Department 表,包含公司所有部门的信息。

代码语言:javascript
复制
-- 创建Department表 --
CREATE TABLE Department(
  Id int(4) not null,
  Name VARCHAR(10)
);

-- 增加2条数据 --
INSERT into Department VALUES(1,'IT');
INSERT into Department VALUES(2,'Sales');

问题一:编写一个 SQL 查询,找出每个部门工资最高的员工。例如,根据上述给定的表格,Max 在 IT 部门有最高工资,Henry 在 Sales 部门有最高工资。

代码语言:javascript
复制
-- 通过排序(必须加上LIMIT,不然结果不正确)与GROUP BY结合求出部门内最高工资,INNER JOIN再关联上部门名 --
SELECT
  D.Name AS Department,
  E.Name AS Employee,
  Salary 
FROM
  ( SELECT * FROM Employee ORDER BY Salary DESC LIMIT 10 ) AS E
  INNER JOIN Department AS D ON E.DepartmentId = D.Id 
GROUP BY
  E.DepartmentId;

问题2:查询部门工资前3的信息。

代码语言:javascript
复制
-- 增加2条数据 --
INSERT INTO Employee VALUES(5,'Janet',69000,1);
INSERT INTO Employee VALUES(6,'Randy',85000,1);

-- 使用窗口函数对各部门的员工工资进行分组排序
SELECT
  ( SELECT D.Name FROM Department AS D WHERE DepartmentId = D.Id ) AS 'Department',
  Name,
  Salary 
FROM
  ( SELECT Name, Salary, DepartmentId, RANK() over ( PARTITION BY DepartmentId ORDER BY Salary DESC ) AS ranking FROM Employee ) AS b 
WHERE
  ranking <= 3;

总结:当ORDEY BY与GROUP BY结合查询时需使用LIMIT分页,不然分组后排序的结果各列值会对不上,问题一SQL语句中如不加LIMIT,查询结果如下:

可以看出IT部门的最高工资查询结果是错误的。问题一可用问题二的窗口函数解法查询,WHERE的条件修改为ranking<2即可。

网优苦短,我用Python

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-12-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 网优小兵玩Python 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档