力扣刷题SQL-619. 只出现一次的最大数字

MyNumbers 表:

+-------------+------+

| Column Name | Type |

+-------------+------+

| num | int |

+-------------+------+

这张表没有主键。可能包含重复数字。这张表的每一行都含有一个整数。

单一数字 是在 MyNumbers 表中只出现一次的数字。

请你编写一个 SQL 查询来报告最大的 单一 数字 。如果不存在 单一数字 ,查询需报告null

查询结果如下例所示。

示例 1:

输入:

MyNumbers 表:88331456

输出:

+-----+

| num |

+-----+

| 6 |

+-----+

解释:单一数字有 1、4、5 和 6 。

6 是最大的单一数字,返回 6 。

示例 2:

输入:

MyNumbers table:8877333

输出:

+------+

| num |

+------+

| null |

+------+

解释:输入的表中不存在单一数字,所以返回 null 。

我敏捷的头脑快速旋转,大概有了个思路:

1.根据num分组

2.计算分组内记录数量等于1

3.从高到低排序

4.取第一条记录

然后快速写了一版错误答案,如下所示:

sql 复制代码
select * from mynumbers
group by num
having count(num)=1
order by num desc
limit 1

炸裂。。。。当不存在单一数字,我的输出为空,而不是null。

后来百度才知道,只有select和某些函数,输出为空的时候才会输出null。而limit正好就是不输出为null,直接输出为空的那个函数。

于是我想到了一种解法:

sql 复制代码
select(
  select num from mynumbers
  group by num
  having count(num)=1
  order by num desc
  limit 1
) as num

然后看了别人的解题思路。

感谢力扣大神【退堂鼓一级表演艺术家】总结的表格:

这是另外一种写法:

sql 复制代码
select max(num) num from 
(
  select num from mynumbers
  group by num
  having count(num)=1
) as t
相关推荐
5***E6855 小时前
【SQL】写SQL查询时,常用到的日期函数
数据库·sql
遇见火星5 小时前
CentOS7 通过源码安装 Redis
数据库·redis·缓存
Mr.朱鹏5 小时前
RocketMQ安装与部署指南
java·数据库·spring·oracle·maven·rocketmq·seata
Coder-coco5 小时前
个人健康管理|基于springboot+vue+个人健康管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·mysql·论文
K哥11255 小时前
【9天Redis系列】基础+全局命令
数据库·redis·缓存
s***46985 小时前
【玩转全栈】----Django模板语法、请求与响应
数据库·python·django
f***R86 小时前
redis分页查询
数据库·redis·缓存
g***72706 小时前
【mysql】导出导入mysql表结构或者数据
数据库·mysql
煎蛋学姐6 小时前
SSM汽车租赁管理系统mfobv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·汽车·ssm 框架·汽车租赁管理系统
w***37516 小时前
Spring 核心技术解析【纯干货版】- Ⅶ:Spring 切面编程模块 Spring-Instrument 模块精讲
前端·数据库·spring