开发者社区> 希帅哥data> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

关于mysql的一些编程题目(一)

简介: 最近我学弟问我sql的一些面试问题,我突然发现我的sql也不是很记得了,所以,我找了一些题目来巩固下我的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`));

输入描述:

输出描述:

emp_no birth_date first_name last_name gender hire_date
10008 1958-02-19 Saniya Kalloufi M 1994-09-15

好了题目出来了,先建表

image

然后,插入如下测试代码


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'); ```  



然后这道题说的是最晚员工,也就是说hire_date字段的最大值,如何比较max的最大值呢?
我们可以用到max()这个函数,所以我的答案是

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

执行,结果正确
image

但是,我学弟说,他用limit也能得到正确的结果,代码如下


select emp_no,birth_date,first_name,last_name,gender,hire_date from employees where hire_date = (select hire_date from employees order by hire_date  limit 1);```  

这样确实是可以的,但是如果我们多插入一行数据

INSERT INTO employees VALUES(10013,'1958-02-19','kang','shifu','M','1994-09-15'); `

这样的话,虽然kanshifu和saniya 都是最晚入职,但是只能选择一个,所以这样的话并不是很可取,所以保险的话,用我的方法

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySQL JDBC编程
本文介绍的JDBC,即Java Database Connectivity,java数据库连接。是一种用于执行SQL语句的Java API,它是Java中的数据库连接规范。这个API由 java.sql.,javax.sql. 包中的一些类和接口组成,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。
0 0
Python编程:利用上下文管理器管理MySQL的链接对象
Python编程:利用上下文管理器管理MySQL的链接对象
0 0
Python编程:pandas读写mysql数据
Python编程:pandas读写mysql数据
0 0
Python编程:records批量插入数据到mysql
Python编程:records批量插入数据到mysql
0 0
Python编程:prettytable打印出类似MySQL的效果
Python编程:prettytable打印出类似MySQL的效果
0 0
MySQL JDBC编程
MySQL JDBC编程
0 0
【面试必刷】Mysql编程题:第七期
【面试必刷】Mysql编程题:第七期
0 0
【面试必刷】Mysql编程题:第六期
【面试必刷】Mysql编程题:第六期
0 0
【面试必刷】Mysql编程题:第五期
【面试必刷】Mysql编程题:第五期
0 0
+关注
希帅哥data
不是因为你感兴趣而擅长某事,而是擅长某事才感兴趣
文章
问答
文章排行榜
最热
最新
相关电子书
更多
让 MySQL 原生分布式触手可及
立即下载
好的 MySQL 兼容可以做到什么程度
立即下载
云数据库RDS MySQL从入门到高阶
立即下载