前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL练习二:查询入职日期倒数第三的员工信息

MySQL练习二:查询入职日期倒数第三的员工信息

原创
作者头像
Mandy的名字被占用了
修改2021-09-22 11:08:59
1K0
修改2021-09-22 11:08:59
举报
文章被收录于专栏:菜鸟成长学习笔记

题目:

有一个员工employees表简况如下:

结果:

请你查找employees里入职员工时间排名倒数第三的员工所有信息,以上例子输出如下:

2A26AB183839E3A01C933AE5A75B6D2F
2A26AB183839E3A01C933AE5A75B6D2F

数据表:

表结构

代码语言:txt
复制
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`));

数据:

insert语句

代码语言:txt
复制
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. 首先此题是查询入职日期倒数第三的日期。
  2. 根据日期需要去插入对应,这一天入职的所有员工的信息。
  3. 此题容易忽略同一天入职日期存在多个,例如2019-06-05存在多个,这时候倒数第三或许就是不真实的倒数第三的日期。因此在查询的时候,需要考虑。可以使用group对日期做一个分组,也可以使用district对日期进行去重,得到的日期就是唯一的。
  4. 根据得到的日期,作为一个临时表,作为查询所有员工的信息。

参考答案:

  1. 使用distinct进行排重查询。
代码语言:txt
复制
select * from employees where hire_date = 
(select distinct hire_date from employees order by hire_date limit 2,1);
  1. 使用group对日期去重查询。
代码语言:txt
复制
select * from employees where hire_date = 
(select hire_date from employees group by hire_date order by hire_date limit 2,1);

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档