LeetCode 180 连续出现的数字

表:Logs

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| num         | varchar |
+-------------+---------+
id 是这个表的主键。

编写一个 SQL 查询,查找所有至少连续出现三次的数字。

返回的结果表中的数据可以按 任意顺序 排列。

查询结果格式如下面的例子所示:

示例 1:

输入:
Logs 表:
+----+-----+
| Id | Num |
+----+-----+
| 1  | 1   |
| 2  | 1   |
| 3  | 1   |
| 4  | 2   |
| 5  | 1   |
| 6  | 2   |
| 7  | 2   |
+----+-----+
输出:
Result 表:
+-----------------+
| ConsecutiveNums |
+-----------------+
| 1               |
+-----------------+
解释:1 是唯一连续出现至少三次的数字。

解题:

// 没有思路

官方解答:

1.用 DISTINCT 和 WHERE 语句

SELECT DISTINCT l1.num AS ConsecutiveNums FROM
logs l1, logs l2, logs l3
WHERE l1.num = l2.num AND l2.num = l3.num and l1.id = l2.id-1 and l2.id = l3.id - 1;

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注