题解 | #查找最晚入职员工的所有信息#

select emp_no,birth_date,first_name,last_name,gender,hire_date
from
(
select *,rank() over(order by hire_date desc) rk
from employees
) a 
where a.rk = 1

为什么写的这么复杂呢?因为题目并没有说清楚最晚入职的员工是有一个人还是多个人,如果是多人的话那么通过简单的倒排,取第一行是不行的。

select * 
from employees
order by hire_date desc
limit 1;
2024年1月7日补充:
没想到精华题解已经说了这点...我还真的没看见
全部评论

相关推荐

05-23 19:02
吉林大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务