牛客网sql练习打卡

目录

第一题

解题: 

1.使用表的子连接

2.使用降序取第一个

第二题

解题:

 1.降序取第三个

2.limit offset

3.子查询



2021/10/8

今天第一次开始尝试使用牛客网练习sql,大二在读,已经有一些sql基础,以后想在数据分析方向发展,开始打基础,加油!

第一题

牛客网sql练习打卡_第1张图片

输入:
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 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');



输出:10008|1958-02-19|Saniya|Kalloufi|M|1994-09-15


 

自己想+看大佬们的答案

解题: 

1.使用表的子连接

select * from employees where hire_date=(select max(hire_date) from employees);

where语句中嵌套一个select语句 使用max函数查询最大的hire_date 从表中找出与此最大值相等的

2.使用降序取第一个

select * from employees order by hire_date desc limit 1;

这个方法有问题,如果最晚入职的不止一个人,这个就错了

应该考虑的问题:
①最晚入职的当天未必就一个人,也许有多人,使用排序并限制得只能取得指定数量的结果

SELECT * 
FROM employees 
WHERE hire_date = (
                   SELECT MAX(hire_date) 
                   FROM employees);

注:日期最大的就是最晚的,日期较早就是较小。

 来自 <练习SQL利器,牛客网SQL实战题库 - 知乎>

第二题

解题:

 1.降序取第三个

   

select * from employees order by hire_date desc limit 2,1;

这种方法不一定可行

limit 2,1 是指:(sql里面的行号是从0开始的)从第三条记录开始取,取一条记录。

2.limit offset

   

select * from employees order by hire_date desc limit 1 offset 2;

limit 1 offset 2:跳过2个从第三条记录开始查询1条记录

当 limit和offset组合使用的时候,limit后面只能有一个参数,表示要取的的数量,offset表示要跳过的数量 。

3.子查询

select * from employees where hire_date=(select distinct hire_date from employees order by hire_date desc limit 1 offset 2);

泛用性更强

select * from employees
where hire_date =
(select hire_date from employees
group by hire_date
order by hire_date desc
limit 1 offset 2);
补充:
若存在多人(如3人)同时在最晚的一天入职的情形,必须要考虑去重(使用distinct或者group by)
distinct和group by的执行顺序都在limit前面

来自 <查找入职员工时间排名倒数第三的员工所有信息_牛客题霸_牛客网>

select * from employees where hire_date=(select distinct hire_date from employees order by hire_date desc limit 1 offset 2);

2021/10/10

停更,呜呜,我还是先打牢基础再开始刷题吧。

今天开始学习《SQL基础教程》,配合书籍和b站上的视频一起学习!

你可能感兴趣的:(sql,数据库,mysql)