当前位置: 首页 > news >正文

力扣-超过经理收入的员工

大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。

文章目录

  • 前言
  • 一、题目:181. 超过经理收入的员工
  • 二、解题
    • 1.正确示范①
      • 提交SQL
      • 运行结果
    • 2.正确示范②
      • 提交SQL
      • 运行结果
    • 3.正确示范③
      • 提交SQL
      • 运行结果
    • 4.正确示范④
      • 提交SQL
      • 运行结果
    • 5.其他
  • 总结


前言


一、题目:181. 超过经理收入的员工

表:Employee

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| name        | varchar |
| salary      | int     |
| managerId   | int     |
+-------------+---------+

Id是该表的主键。
该表的每一行都表示雇员的ID、姓名、工资和经理的ID。

编写一个SQL查询来查找收入比经理高的员工。
以 任意顺序 返回结果表。
查询结果格式如下所示。

输入: 
Employee 表:
+----+-------+--------+-----------+
| id | name  | salary | managerId |
+----+-------+--------+-----------+
| 1  | Joe   | 70000  | 3         |
| 2  | Henry | 80000  | 4         |
| 3  | Sam   | 60000  | Null      |
| 4  | Max   | 90000  | Null      |
+----+-------+--------+-----------+
输出: 
+----------+
| Employee |
+----------+
| Joe      |
+----------+

解释: Joe 是唯一挣得比经理多的雇员。

二、解题

1.正确示范①

提交SQL

select u1.name Employee from Employee u1,Employee u2 
where u1.managerId=u2.id 
and u1.salary>u2.salary;

运行结果

2.正确示范②

提交SQL

select u1.name Employee from Employee u1
where salary>(select salary from Employee u2 where  u1.managerId=u2.id
);

运行结果

3.正确示范③

提交SQL

select u1.name Employee
from Employee u1
left join Employee u2 
on u1.managerId=u2.id
where u1.salary>u2.salary;

运行结果

4.正确示范④

提交SQL

select u1.name Employee
from Employee u1
join Employee u2 
on u1.managerId=u2.id
where u1.salary>u2.salary;

运行结果

5.其他


总结

正确示范①思路:
方法1会产生笛卡尔积,通过where限定符合规则的条件即可
where + and
where u1.managerId=u2.id and u1.salary>u2.salary
正确示范②思路:
采用子查询方式
where + 子查询
where salary>(select salary from Employee u2 where u1.managerId=u2.id)
正确示范③思路:
left join + on + where
注意这里的where在该题目中不能换作and
正确示范④思路:
join + on +where 或者 join + on +and

http://www.lryc.cn/news/40513.html

相关文章:

  • 决策树基础知识点解读
  • 【C++】入门知识之 命名空间与输入输出
  • redis持久化的几种方式
  • 数据持久化层--查询分离
  • 一文读懂Js中的this指向
  • 零费用、零学习成本,用户快速可自定义json格式
  • 2023年全国最新高校辅导员精选真题及答案25
  • 二、数据结构-线性表
  • CGAL 点云上采样
  • 阿里云短信验证码实战
  • Android APP隐私合规检测工具Camille使用
  • 手把手学会DFS (递归入门)
  • 由《三体》太阳文明末日场景想到的……
  • es6的Proxy与Reflect
  • Linux环境部署vue项目 + nginx访问(包含nginx配置简介)
  • 到底什么是跨域,如何解决跨域(常见的几种跨域解决方案)?
  • pm3包1.4版本发布----一个用于3组倾向性评分的R包
  • 没有关系的话,那就去建立关系吧
  • Vue项目
  • 【webrtc】ICE 到VCMPacket的视频内存分配
  • 进阶C语言——指针(二)【题目练习】
  • Ajax简介
  • ChatGPT 4 测试 两数比较大小问题。
  • SSM-CRUD整合视频教程:Spring、SpringMVC、MyBatis、bootstrap、pagehelper、JSR303后端校验
  • Linux常用命令——基于Ubuntu22.04
  • Sentinel
  • 再也不想去字节跳动面试了,6年测开面试遭到这样打击.....
  • 【深度解刨C语言】符号篇(全)
  • VS Code 将推出更多 AI 功能给 Java 开发者
  • 关于利用FFT分析时域信号幅相的思考与验证