<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          MySQL練習(xí)十:查找入職員工時間排名倒數(shù)第三的員工所有信息

          共 2000字,需瀏覽 4分鐘

           ·

          2021-09-21 16:07

          題目:有一個員工employees表簡況如下:

          0BFB4D140D9C3E92AF681D9F9CB92D55 (1)

          結(jié)果:請你查找employees里入職員工時間排名倒數(shù)第三的員工所有信息,以上例子輸出如下:

          2A26AB183839E3A01C933AE5A75B6D2F

          數(shù)據(jù)表:表結(jié)構(gòu)

          drop table if exists  `employees` ; 
          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`));

          數(shù)據(jù):insert語句

          INSERT INTO employees VALUES(10001,'1953-09-02','Georgi','Facello','M','1986-06-26');
          INSERT INTO employees VALUES(10002,'1964-06-02','Bezalel','Simmel','F','1985-11-21');
          INSERT INTO employees VALUES(10003,'1959-12-03','Parto','Bamford','M','1986-08-28');
          INSERT INTO employees VALUES(10004,'1954-05-01','Chirstian','Koblick','M','1986-12-01');
          INSERT INTO employees VALUES(10005,'1955-01-21','Kyoichi','Maliniak','M','1989-09-12');
          INSERT INTO employees VALUES(10006,'1953-04-20','Anneke','Preusig','F','1989-06-02');
          INSERT INTO employees VALUES(10007,'1957-05-23','Tzvetan','Zielinski','F','1989-02-10');
          INSERT INTO employees VALUES(10008,'1958-02-19','Saniya','Kalloufi','M','1994-09-15');
          INSERT INTO employees VALUES(10009,'1952-04-19','Sumant','Peac','F','1985-02-18');
          INSERT INTO employees VALUES(10010,'1963-06-01','Duangkaew','Piveteau','F','1989-08-24');
          INSERT INTO employees VALUES(10011,'1953-11-07','Mary','Sluis','F','1990-01-22');

          解題思路:

          1. 首先此題是查詢?nèi)肼毴掌诘箶?shù)第三的日期。

          2. 根據(jù)日期需要去插入對應(yīng),這一天入職的所有員工的信息。

          3. 此題容易忽略同一天入職日期存在多個,例如2019-06-05存在多個,這時候倒數(shù)第三或許就是不真實的倒數(shù)第三的日期。因此在查詢的時候,需要考慮。可以使用group對日期做一個分組,也可以使用district對日期進(jìn)行去重,得到的日期就是唯一的。

          4. 根據(jù)得到的日期,作為一個臨時表,作為查詢所有員工的信息。

          參考答案:

          1. 使用distinct進(jìn)行排重查詢。
          select * from employees where hire_date = 
          (select distinct hire_date from employees order by hire_date limit 2,1);
          1. 使用group對日期去重查詢。
          select * from employees where hire_date = 
          (select hire_date from employees group by hire_date order by hire_date limit 2,1);

          推薦試題:

          1. MySQL練習(xí)九:查找最晚入職員工的所有信息

          2. SQL練習(xí)八

          3. MySQL練習(xí)七

          4. MySQL練習(xí)六


          瀏覽 105
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  一级爱ai高清免费在线视频 | 丁香五月激情网 | 操嫩逼| 国产黄色精品 | 国产黄视频在线看 |