网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
今天刷MYSQL题的时候刷到这样一个题:
编写一个 SQL 查询,获取 Employee 表中第二高的薪水(Salary) 。
+----+--------+
| Id | Salary |
+----+--------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
+----+--------+
例如上述 Employee 表,SQL查询应该返回 200 作为第二高的薪水。如果不存在第二高的薪水,那么查询应返回 null。
+---------------------+
| SecondHighestSalary |
+---------------------+
| 200 |
+---------------------+
初看了一眼题时,脑子还有一点迷糊,对于数值最大的和最小的,可以使用max和min去查询出来,但对于第N的就不好找了,思考了一会儿了,心里大致有二个思路:
第一个思路,因为是求的第二高,那就把最高的找出来,小于的它的,然后再排列一下取最大的就行了
# 1、求最大的值
select max(Salary)
from Employee;
# 2、求小于最大的值
select max(Salary) as SecondHighestSalary
from Employee
where Salary < (select max(Salary) from Employee);
第二个思路,先将所有值倒序排,然后输出第二个就行
select Salary as SecondHighestSalary
from Employee
order by Salary desc
limit 1,1;
#若是有相同的值,只输出一个,所以加上distinct
select distinct Salary as SecondHighestSalary
from Employee
order by Salary desc
limit 1,1;
然后去执行语句的时候,发现与预期结果相同,心里窃喜,这就算出来了。。。
输入:
{"headers": {"Employee": ["Id", "Salary"]}, "rows": {"Employee": [[1, 100], [2, 200], [3, 300]]}}
输出:
{"headers": ["Salary"], "values": [[200]]}
预期结果:
{"headers": ["SecondHighestSalary"], "values": [[200]]}
随着去提交代码之后,返回的结果却是 解答错误,满头的黑人问号脸,哪里错了?怎么错了的?
查看错误详情:
输入:
{"headers": {"Employee": ["Id", "Salary"]}, "rows": {"Employee": [[1, 100]]}}
输出:
{"headers": ["SecondHighestSalary"], "values": []}
预期:
{"headers":["SecondHighestSalary"],"values":[[null]]}
恍然大悟,原来是没有考虑”如果不存在第二高的薪水,那么查询应返回 null“这个情况,找到问题就好办了,这也是我们在代码中写sql时常没有考虑到异常情况。
如果查询不到数据,应该返回什么值,需不需对这种情况进行封装的考虑,这道题里已经要求了,若是没有查询到就输出null,所以再次修改了我的sql:
select ifnull(
(select Salary from Employee order by Salary desc limit 1,1), null) as SecondHighestSalary;
结果:顺利通过
这道题主要考察的知识点就是LIMIT的使用和对NULL的处理,之前写过一篇与LIMIT有关的文章,LIMIT在实际使用过程使用情况非常普遍。
知识点总结:
LIMIT
LIMIT 一般都是放在SQL语句的最后,是对展示的结果做一个限制输出,比如查询了十条记录,但只展示一条,那就可以在SQL语句后面加一个LIMIT 1。
LIMIT 语法:
SELECT column_list
FROM table1
ORDER BY column_list
LIMIT row_count OFFSET offset_count;
# row_count 表示 返回的记录数
# offset为偏移量,表示从哪条数据开始返回,使用过程中也可以省略
举例:
1、查询出雇员表中的5条记录
select * from Employee limit 5;
2、查询出雇员表第二条数据后的5条记录(不包括第二条数据)
#不显示最前面二条数据,从第三条数据开始展示
select * from Employee 5 offset 2;
==
select * from Employee 2,5;-->这是我最喜欢使用的写法
IFNULL()
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
真正的技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!