SQL LeetCode刷题系列(六)——连续出现的数字

本文介绍了一种使用SQL查询所有至少连续出现三次的数字的方法。通过子查询和多表连接,巧妙地判断数字的连续性,适用于需要处理大量数据的场景。

题目描述

编写一个 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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值