leetcode-sql数据库面试题冲刺(高频SQL五十题)

题目:

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 。

思路:

结合题目的查询条件为“找出最大的单一数字 。如果不存在单一数字 ,则返回 null ”:
a)单一数字,使用GROUP BY语句分组、COUNT函数计算出该数字出现次数,COUNT(num) = 1即为单一数字。
b)最大的单一数字,使用ORDER BY语句进行排序,再使用LIMIT 1获取从大到小排序后的第一条记录数字,即为最大值。
c)如果不存在单一数字 ,则返回 null,使用CASE WHEN语句做判断,如果有符合条件的记录则返回数值内容,没有则返回null。

代码:

SELECT CASE WHEN COUNT(num) = 1 
THEN num 
ELSE null end AS num
FROM MyNumbers
GROUP BY num
ORDER BY num DESC
LIMIT 1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值