大家好,又见面了,我是你们的朋友全栈君。
1、查找最晚入职员工的所有信息
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`));
SELECT * FROM employees ORDER BY hire_date DESC LIMIT 1;
limit关键字用法:https://blog.csdn.net/BlackPlus28/article/details/83057392
SELECT * FROM employees WHERE hire_date = (SELECT MAX(hire_date) FROM employees);
简单想,上面两种方法都可以解决的。但limit查询有局限性。但使用limit方法查询只能查出最后一条数据,但要是最后一天入职多员工,就会出现问题。因此使用子查询更为合理,先将入职日期最大的全部查询来作为条件再次查询就可以。
2、查找入职员工时间排名倒数第三的员工所有信息
SELECT * FROM employees WHERE hire_date = (
SELECT DISTINCT hire_date FROM employees ORDER BY hire_date DESC LIMIT 2,1)
表结构:
查询结果:
思路:首先要去重,不然查出来的只是员工倒数的第三个员工而已,只有去重之后,才能查出入职时间倒数第三的员工。
如果有不同看法,或者是文中写错的地方,麻烦大佬留言指正文章错误,谢谢!!!
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/147225.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...