高频 SQL 50 题(基础版)| 180. 连续出现的数字
表:Logs
±------------±--------+
| Column Name | Type |
±------------±--------+
| id | int |
| num | varchar |
±------------±--------+
在 SQL 中,id 是该表的主键。
id 是一个自增列。
找出所有至少连续出现三次的数字。
返回的结果表中的数据可以按 任意顺序 排列。
结果格式如下面的例子所示:
示例 1:
输入:
Logs 表:
±—±----+
| id | num |
±—±----+
| 1 | 1 |
| 2 | 1 |
| 3 | 1 |
| 4 | 2 |
| 5 | 1 |
| 6 | 2 |
| 7 | 2 |
±—±----+
输出:
Result 表:
±----------------+
| ConsecutiveNums |
±----------------+
| 1 |
±----------------+
解释:1 是唯一连续出现至少三次的数字。
解1:开窗函数
SELECT DISTINCT num AS ConsecutiveNums
FROM
(
SELECT
num,
lead (num, 1) over () AS num1,
lead (num, 2) over () AS num2
FROMlogs
) t
WHERE t.num = num1 AND t.num = num2
解2:声明变量
SELECT DISTINCT ConsecutiveNums
FROM(
SELECT
IF(@p_num = num ,@count := @count + 1,@count:=1) AS count,
@p_num := num AS ConsecutiveNums
FROM
LOGS,(SELECT@count := 1,@p_num := NULL) r
) S
WHERE count>=3