sql實戰:查找入職員工時間排名倒數第三的員工所有信息

查找入職員工時間排名倒數第三的員工所有信息

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)

發佈了25 篇原創文章 · 獲贊 23 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章