该题目来源于力扣:
619. 只出现一次的最大数字 - 力扣(LeetCode)
题目要求:
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 。
思路流程:
要实现两个主要的需求:返回最大的唯一值,不是唯一值返回空值。这时候可以想到利用子查询来做这道题:首先查询num的最大值来自于已经查询过的唯一值的一串数据,如果有唯一值,num的最大值便会从这个子查询中查找相应的数据,而如果都是重复值,那么子查询中返回的都是空值,那么max(num)查询返回的也是空值,算是一个特性吧。
注意给要查询的值和子查询的值都要起别名,否则会报错
代码实现:
SELECT MAX(num) AS num
FROM(
SELECT num
from mynumbers
group by num
having count(num)=1
) AS mynumber