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

题解
SELECT DISTINCT(t.Num1) ConsecutiveNums
FROM
(SELECT L1.Id
,L1.Num Num1
,L2.Num Num2
,L3.Num Num3
FROM
Logs AS L1
INNER JOIN
Logs AS L2
ON L1.Id=L2.Id+1
INNER JOIN
Logs AS L3
ON L1.Id=L3.Id+2
ORDER BY L1.Id) t
WHERE Num1=Num2
AND Num2=Num3;
解题思路
这个题看起来简单,其实比较复杂,难度是中等,要用到子查询,多表连接等,要判断一个数字连续出现三次,需要拼接三个表,而且不是直接连接,而是每次错开一个,所以第一个表和第二个表连接时有条件 ON L1.Id=L2.Id+1
再连接第三个表时有条件ON L1.Id=L3.Id+2
最后再根据第一个表的id 来排序,过滤条件是三个表的num一样,也就是Num1=Num2
AND Num2=Num3;
本文介绍了一种使用SQL查询所有至少连续出现三次的数字的方法。通过子查询和多表连接,巧妙地判断数字的连续性,适用于需要处理大量数据的场景。
——连续出现的数字&spm=1001.2101.3001.5002&articleId=102489389&d=1&t=3&u=e42dbe4b0c6c417e9e4afbc409c8fdf9)
3807

被折叠的 条评论
为什么被折叠?



