详解力扣高频SQL50题之619. 只出现一次的最大数字【简单】
传送门:619. 只出现一次的最大数字
题目
MyNumbers 表:
±------------±-----+
| Column Name | Type |
±------------±-----+
| num | int |
±------------±-----+
该表可能包含重复项(换句话说,在SQL中,该表没有主键)。
这张表的每一行都含有一个整数。
单一数字 是在 MyNumbers 表中只出现一次的数字。
找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null 。
查询结果如下例所示。
示例 1:
输入:
MyNumbers 表:
±----+
| num |
±----+
| 8 |
| 8 |
| 3 |
| 3 |
| 1 |
| 4 |
| 5 |
| 6 |
±----+
输出:
±----+
| num |
±----+
| 6 |
±----+
解释:单一数字有 1、4、5 和 6 。
6 是最大的单一数字,返回 6 。
示例 2:
输入:
MyNumbers table:
±----+
| num |
±----+
| 8 |
| 8 |
| 7 |
| 7 |
| 3 |
| 3 |
| 3 |
±----+
输出:
±-----+
| num |
±-----+
| null |
±-----+
解释:输入的表中不存在单一数字,所以返回 null 。
解析
显然用group by+count()+max(),但是注意group by+count()得到的是在组内的数字而不是全部数字,不能直接用max(),得再嵌套一层查询再用。
算法(标准SQL)
查询数字表,按num分组,统计组内数量=1的记录,作为一张表,再查询该表,对num求最大值并返回。
代码(标准SQL)
select max(num)as num
from(select *
from MyNumbers
group by num
having count(*)=1);