【SQL高频基础题】619.只出现一次的最大数字
题目:
MyNumbers
表:
+-------------+------+ | Column Name | Type | +-------------+------+ | num | int | +-------------+------+ 该表可能包含重复项(换句话说,在SQL中,该表没有主键)。 这张表的每一行都含有一个整数。
单一数字 是在 MyNumbers
表中只出现一次的数字。
找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null
。
查询结果如下例所示。
解题:
这题,我写了2种方法,第二种是参考答案后写出来的。
select ifnull(max(b.num),null) as num from (select num from MyNumbers group by num having count(num) =1) b
其实两者原理类似,都是先规定num的范围,然后再从里面摘选。你觉得哪种更好理解一点?
select ifnull(max(num),null) as num from Mynumbers where num in (select num from MyNumbers group by num having count(num) = 1)
写下来之后,我感觉第二种好像更好理解一点。