「已注销」 2022-03-03 20:57 采纳率: 100%
浏览 18
已结题

请教SQL自连接的实现?

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

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

  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-03 21:38
    关注

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

    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构造了一个远超原表记录数的数据

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 修改了问题 3月3日
  • 创建了问题 3月3日