最近工作时候,发现自己sql写的真是很垃圾 所以 上letcode刷题去了
解题思路
https://leetcode-cn.com/problems/second-highest-salary/
首先 这个题我不会,然后我就去 评论区找了答案 ,开始反向解析
初始思路:select Salary as SecondHighestSalary from Employee order by Salary desc limit 1 offset 1
然后我就发现,过不了 Salary 均为 200 还是输出
2.0: 这时候我想到了 distinct 所以 第二版提交:
select Salary as SecondHighestSalary from Employee order by Salary desc limit 1 offset 1
有个问题 就是 没有办法输出 null
3.0 去了评论区 看到了select null 的用法 ;查了下如果查询表没有记录,select 就会输出null
如何让 select 列是null呢 ,写一个字表一个子表 如果出现 Salary 均为 200 字表的结果就是不存在 等同于、
字表就是个空表 ,然后就可以select null 的 (null) 构造出来了
select (select distinct Salary from Employee order by Salary desc limit 1 offset 1) as SecondHighestSalary
select null 用法参考https://blog.csdn.net/lewky_liu/article/details/78290971