查找入职员工时间排名倒数第三的员工所有信息SQL实现

时间:2021-04-25 17:16:14

题目描述

查找入职员工时间排名倒数第三的员工所有信息
CREATE TABLE `employees` (
`emp_no` int(11) NOT NULL,
`birth_date` date NOT NULL,
`first_name` varchar(14) NOT NULL,
`last_name` varchar(16) NOT NULL,
`gender` char(1) NOT NULL,
`hire_date` date NOT NULL,
PRIMARY KEY (`emp_no`));
 

SQL实现(当存在多个员工同时入职时,两种方法的结果应该会有所不同)

方法1:

select * from employees
where hire_date =
(select distinct hire_date from employees
order by hire_date desc limit 2,1)

or

方法2:

select * from employees
order by hire_date desc limit 2,1

LIMIT m,n : 表示从第m+1条开始,取n条数据;
LIMIT n : 表示从第0条开始,取n条数据,是limit(0,n)的缩写。
本题limit 2,1 表示从第(2+1)条数据开始,取一条数据,即入职员工时间排名倒数第三的员工。