SQL-leetcode—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 。
题解
单一数字 是在 MyNumbers 表中只出现一次的数字。
找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null 。
分组求单次最大值:
你应该想到的是:group by order by max 、count over?
方法一
-- 总是监测无法通过,因为无数据的时候要返回null,咋返回呢?
select
num as num
from MyNumbers
group by num
having count(num)=1
order by num Desc
limit 1
-- 找了试了下各种函数好像都不行,什么if、isnull等待
-- 最终使用了个笨方法 union 个null进来呗
-- 把null塞进来,查不出来不就剩下null了吗?
select null as num
union
select
num as num
from MyNumbers
group by num
having count(num)=1
order by num Desc
limit 1
方法二 count over + max
with tmp as (
select
num as num
,count(num) over (partition by num order by num Desc) as cno
from MyNumbers
)
select max(num) as num from tmp where cno=1