草庐IT

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

空空star 2023-04-19 原文

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

文章目录


前言


一、题目: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

有关力扣-超过经理收入的员工的更多相关文章

  1. ruby-on-rails - ActiveRecord::QueryCache#call 占用了超过 70% 的执行时间 - 2

    NewRelic向我展示了应用服务器中超过80%的执行时间发生在“MiddlewareActiveRecord::QueryCache#call”中这里是相关测试代码的要点(尽管我在其他API端点上看到了类似的结果)。Gist我正在AWSElasticBeanstalk上的t2.medium实例和t2.smallPostgresRDSDB上运行应用程序服务器,max_connections设置为100。我正在通过loader.io对此进行测试,对100个用户进行测试使用维护客户端负载设置(这意味着每分钟大约6000个请求)。有谁知道为什么QueryCache花费这么多时间?

  2. ruby - 如果超过 5 秒,如何退出使用 Ruby 运行的进程? - 2

    我正在用Ruby实现一个检查系统。它运行具有不同测试的可执行文件。如果解决方案不正确,则可能需要很长时间才能完成某些严格的测试。这就是为什么我想将执行时间限制为5秒。我正在使用system()函数来运行可执行文件:system("./solution");.NET有一个很棒的WaitForExit()方法,那么Ruby呢?有没有办法将外部进程的执行时间限制为5秒?谢谢 最佳答案 您可以使用标准超时库,如下所示:require'timeout'Timeout::timeout(5){system("./solution")}这样您就不

  3. ruby-on-rails - 你如何说服你的经理你的项目需要大量重构? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭8年前。Improvethisquestion我作为承包商加入了一个Rails项目。该项目已经进行了一年多。代码由大约10名不同的开发人员编写,其中大多数也是承包商。他们有不同的代码风格。其中一些来自Java。该代码在metric_fu方面得分很低。许多函数非常长(100-300行)。有些函数有大量的逻辑分支、循环和递归。每个请求都会生成大量的sql查询。性能很差。许多过时的代码从未使用过但从未有机会被清理。核心架构明显错误或设计过度

  4. ruby-on-rails - Rails、Minitest 和 Guard - 为什么 rb-fsevent 占用了超过 100% 的 CPU? - 2

    我在我的Rails应用程序中运行守卫,测试套件(最小的)最近停止正常工作。如果幸运的话,它会运行所有测试一次,也许两次。在那之后,即使是一个小的测试文件被更改也需要很长时间才能响应,以至于使用gem变得徒劳无功。在测试运行时跟随top,我可以看到有一个ruby​​进程持续占用了超过100%的CPU。即使所有测试都已运行并且我没有对文件进行任何更改。ruby进程是:/Users/Bodacious/.rvm/gems/ruby-2.0.0-p247@MyApp/gems/rb-fsevent-0.9.3/bin/fsevent_watch--latency0.1/Users/Bodaio

  5. ruby - 在 object.initialize 中,使用 self 是不是更好。超过 @? - 2

    有一种约定,在可能的情况下,通过对象的实例变量来引用对象的属性。PracticalObject-OrientedDesigninRuby说:Alwayswrapinstancevariablesinaccessormethodsinsteadofdirectlyreferringtovariables...这显示了一个例子,我已经释义了:classGearattr_reader:chainring,:cog...defratio#thisisbad#@chainring/@cog.to_f#thisisgoodchainring/cog.to_fend我看到使用实例变量创建新对象的最常

  6. ruby - Cookie 数据大小超过 4K - 但其 'only' 1100 字节已加密 - 2

    我有一个使用Rack::Session::Cookie的Sinatra应用useRack::Session::Cookie,:key=>'my.key',:path=>'/',:expire_after=>3600,#Inseconds:secret=>'something'我在session中有一个地方可以设置数据,我转储了session,大约在erb调用之前有600字节puts"sessionis#{session.inspect}"==>400bytesoftext然后我得到Warning!Rack::Session::Cookiedatasizeexceeds4K.Warnin

  7. ruby-on-rails - 每个请求的 Ruby GC 执行超过 ~250-320 毫秒 - 2

    我有一个ruby​​onrails应用程序。我正在调查我的NewRelic门户中的Apdex下降情况,我发现平均有250-320毫秒的时间花在了GC执行上。这是一个非常令人不安的数字。我在下面包含了一个屏幕截图。我的Ruby版本是:ruby1.9.3p194(2012-04-20修订版35410)[x86_64-linux]任何关于调整它的建议都是理想的。这个数字应该低得多。 最佳答案 您在GC上花费了很多时间,因为您经常运行GC。默认情况下,Ruby设置适用于小型脚本而非大型应用程序的GC参数。尝试使用以下环境参数集启动您的应用:

  8. javascript - 超过最大更新深度。当组件在 componentWillUpdate 或 componentDidUpdate 中重复调用 setState 时,可能会发生这种情况 - 2

    我正在制作这个Conway的生命游戏React项目,它工作得很好,但是当我添加最后几个按钮来清除棋盘时,React的一些其他功能给了我这个错误Maximumupdatedepthexceeded.ThiscanhappenwhenacomponentrepeatedlycallssetStateinsidecomponentWillUpdateorcomponentDidUpdate.Reactlimitsthenumberofnestedupdatestopreventinfiniteloops.从它向我展示的代码片段来看,clear()函数似乎是这里的问题,但我认为我没有在rend

  9. javascript - Wow.js 不会加载延迟超过 1 秒的动画。为什么? - 2

    我在wow.js中使用animate.css。第三个,数据延迟超过一秒,不fadeInLeft。它正常淡入(不是从左侧淡入)。有人遇到过这个问题吗?我该如何解决?--这是我的看法。我在页面上有三个列表项。Text1Text2Text2 最佳答案 我知道这个帖子有点老,但我想我会发布我所知道的:尝试使用节类。Text1Text2Text3 关于javascript-Wow.js不会加载延迟超过1秒的动画。为什么?,我们在StackOverflow上找到一个类似的问题:

  10. 面试总结+力扣第二天刷题 - 2

    一.面试总结    4月20号下午进行了一场大数据视频面试,总结一下踩坑点:    1.确定面试后,第一件事要和HR确定面试方式,具体时间、地点、什么软件、岗位JD等必须信息。        这里很多人有一个思想误区,认为问的太多会给HR不好的印象;其实大可不必,如果你通过了简历筛选,你就有权力使用公司招聘的人力资源。    2.要在面试10分钟前就进入面试的环境中,以防突发事件。    3.面试最开始都会有一个自我介绍环节,这个自我介绍环节,一定要慎之又慎,最好写下来,让朋友、长辈等审核多遍。    注:我面试时,在这踩了一个坑,自我介绍的时候踩了我要面试的岗位一脚,被技术面试官抓住了这一点

随机推荐