m0_46569238 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日

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?