请教SQL自连接的实现?

/*
题目:返回公司工资最少的员工的last_name, job_id和salary
*/
SELECT last_name, job_id, salary
FROM employees
WHERE salary = (
               SELECT MIN(salary)
               FROM employees
               );

请问用自连接的方式如何实现?

用开窗函数只需要查一次这个表,不知道为啥要用什么自连接

select last_name, job_id, salary from 
(SELECT last_name, job_id, salary,dense_rank() over(order by salary desc ) rk
FROM employees) as e
where rk=1

自连接无非就是同一个表写两个别名,然后join起来,但你这个是要找工资最少的,那么当然是min一下,但这个数据聚合后就不是同一个表了,所以换个思路,

select a.last_name,a. job_id, a.salary
from employees a left join employees b 
on a.salary >b.salary
where b.salary is null

即在b表中不存在比a表中还小的数据时, a表这一行就是最小。
虽然结果是正确的,但是,这个sql极其浪费性能,把where条件去掉就能发现,这个join构造了一个远超原表记录数的数据

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632