查找入職員工時間排名倒數第三的員工所有信息
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`));
下面兩種答案都能AC,但仔細想想卻有不同:
(1)select * from employees order by hire_date desc limit 2,1;
(2)select * from employees where hire_date = (select hire_date from employees order by hire_date desc limit 2,1);
答案(1)忽略了多名員工在入職時間上有可能相同的實際情況,結果只檢索出了一條
答案(2)則將可能重複的情況檢索得出
注:
order by 排序操作;
desc表示逆向(從大到小),與之相對應的默認項asc表示正向(從小到大)
limit m,n 表示從第m+1條開始,取n條數據
limit n 表示從第0條開始,取n條數據 相當於limit(0,n)