织梦网站名称修改/线上营销方案
阅读之前,请牛刀小试:https://leetcode-cn.com/problems/employees-earning-more-than-their-managers/
本系列教程,基于19个案例来探索SQL编程的艺术。 SQL 是一门结构化查询语言,更是一门面向集合的语言。
一 、题目:超过经理收入的员工
Employee 表包含所有员工,他们的经理也属于员工。每个员工都有一个 Id,此外还有一列对应员工的经理的 Id。
加粗样式
Id | Name | Salary | ManagerId |
---|---|---|---|
1 | Joe | 70000 | 3 |
2 | Henry | 80000 | 4 |
3 | Sam | 60000 | NULL |
4 | Max | 90000 | NULL |
给定 Employee 表,编写一个 SQL 查询,该查询可以获取收入超过他们经理的员工的姓名。在上面的表格中,Joe 是唯一一个收入超过他的经理的员工。
Employee |
---|
Joe |
应用场景
自关联、多表连接查询
二、准备:创建表插入数据
DROP TABLE IF EXISTS Employee;
CREATE TABLE Employee (id INT PRIMARY KEY,name VARCHAR(200),salary DECIMAL(10,2),managerid INT
) ;
INSERT INTO employee (id,name,salary,managerid)VALUES
(1,'Joe',70000,3),
(2,'Henry',80000,3),
(3,'Sam',60000,null),
(4,'Max',90000,null);
三、解法:条条大路
本题比较简单,不需要做过多讲解,罗列一些解法,拓展一下解题思路,SQL解法变化多样,绝对不会说某道题就只有一种解法。
3.1 解法一 : 自连接
自连接查询,这种表的设计思想就是树形结构的思想。每条记录都使用一个字段去存储父节点的id.
SELECT e.Name AS Employee
FROM Employee e
INNER JOIN Employee m ON e.ManagerId = m.Id
WHERE e.Salary > m.Salary;
3.2 解法二:子查询
注意: 一般子查询是能够转换成关联查询的,至于这两种的性能谁更好,很难说清楚。
SELECT e.Name AS Employee
FROM Employee e
WHERE ManagerId IS NOT NULLAND Salary > (SELECT SalaryFROM EmployeeWHERE ID = e.ManagerId
)
3.2 其他
SQL编程更注重思想。