181. 超过经理收入的员工

在给定的SQL架构中,有一个Employee表包含所有员工信息,包括他们的经理ID。题目要求编写一个SQL查询,以获取那些收入超过其经理的员工姓名。在示例数据中,Joe是唯一一个满足条件的员工。提供的SQL语句通过连接Employee表自身,比较员工薪水与其经理薪水来实现这一目标。
摘要由CSDN通过智能技术生成

SQL架构

Create table If Not Exists Employee (Id int, Name varchar(255), Salary int, ManagerId int)
Truncate table Employee
insert into Employee (Id, Name, Salary, ManagerId) values ('1', 'Joe', '70000', '3')
insert into Employee (Id, Name, Salary, ManagerId) values ('2', 'Henry', '80000', '4')
insert into Employee (Id, Name, Salary, ManagerId) values ('3', 'Sam', '60000', 'None')
insert into Employee (Id, Name, Salary, ManagerId) values ('4', 'Max', '90000', 'None')

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      |
+----------+

SQL语句

# Write your MySQL query statement below
SELECT
    a.Name AS 'Employee'
FROM
    Employee AS a,
    Employee AS b
WHERE
    a.ManagerId = b.Id
        AND a.Salary > b.Salary
;

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/employees-earning-more-than-their-managers
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
帮我写一段C++代码,要求如下:某软件公司员工(Employee)可以分为现有两类人员:行政管理人员(Manager)和项目开发人员(Developer)。现在需要对公司的人员信息进行统一管理,存储人员的编号(number)、姓名(name)、职务级别(position)、每月固定奖金(monthBonus)、每月月收入(monthIncome)和计算每月月收入(void calculateMonthIncome()),并且能够显示员工全部信息(void showInfo())。 行政管理人员和项目开发人员均划分成三个等级,行政管理人员分为总经理(级别为1)、部门经理(级别为2)和小组长(级别为3);行政管理人员月收入的计算公式为12000*(3-级别+1)/3+每月固定奖金,固定资金为3500元/月。 项目开发人员分为工作时间不满一年的(级别为3)、工作时间超过一年不到三年的(级别为2)和工龄在三年以上的(级别为1);项目开发人员月收入的计算公式为6000*(3-级别+1)/3+奖金,奖金为其加班的小时数*40元/小时+每月固定奖金500元。 试编程实现上述人员管理,用虚函数实现体现出多态性。将Employee类的声明放在employee.h文件中、Employee类的实现放在employee.cpp文件中;将Manager类的声明放在manager.h文件中、Manager类的实现放在manager.cpp文件中;将Developer类的声明放在developer.h文件中、Developer类的实现放在developer.cpp文件中;主函数放在main.cpp文件中。
最新发布
06-06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值