/*
题目:返回公司工资最少的员工的last_name, job_id和salary
*/
SELECT last_name, job_id, salary
FROM employees
WHERE salary = (
SELECT MIN(salary)
FROM employees
);
请问用自连接的方式如何实现?
/*
题目:返回公司工资最少的员工的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构造了一个远超原表记录数的数据