[SQL智慧航行者] - 连续出现的数字

话不多说, 先看数据表信息.

数据表信息:

logs 表, 包含对应的编号 id, 和出现的数字Num.

复制代码
+----+-----+
| Id | Num |
+----+-----+
| 1  |  1  |
| 2  |  1  |
| 3  |  1  |
| 4  |  2  |
| 5  |  1  |
| 6  |  2  |
| 7  |  2  |
+----+-----+

话不多说, 再看需求~

需求:

编写一个 SQL 查询,查找所有至少连续出现三次的数字。输出如下结果:

复制代码
+-----------------+
| ConsecutiveNums |
+-----------------+
| 1               |
+-----------------+

话不多说, 进行拆解~

拆解:

这里首先想到的是使用lead窗口函数, 将当前结果往后移动一个, 往后移动二个, 当三者结果一致, 则说明该数字出现过三次.

直接上SQL语句:

sql 复制代码
select 
id, num,
lead(num, 1) over(order by id) as num_1,
lead(num, 2) over(order by id) as num_2
from logs 
; 

结果如下:

再加上限制条件:

sql 复制代码
select t.id   
from (
    select 
    id, num,
    lead(num, 1) over(order by id) as num_1,
    lead(num, 2) over(order by id) as num_2
    from logs 
) as t 
where t.num = t.num_1
and t.num = t.num_2
;

就可以得到最终的结果:

最后给大家介绍一下我这边的操作步骤, 想要自己测试的话, 可以参考:

sql 复制代码
CREATE TABLE logs (
    Id INT,
    Num INT
);

INSERT INTO logs (Id, Num)
VALUES (1, 1), (2, 1), (3, 1), (4, 2), (5, 1), (6, 2), (7, 2);
相关推荐
2301_8002561144 分钟前
8.2 空间查询基本组件 核心知识点总结
数据库·人工智能·算法
吃喝不愁霸王餐APP开发者1 小时前
霸王餐API文档自动化:Spring REST Docs与Asciidoctor多模块聚合
数据库·spring·自动化
小张程序人生1 小时前
MySQL一主一从搭建详细讲解
mysql
默恋~微凉1 小时前
Mysql 备份与还原
数据库·mysql
研华科技Advantech2 小时前
储能AI化的数据瓶颈与破解路径:研华全栈方案实践分析
数据库·人工智能·储能·智能体
大锦终2 小时前
【MySQL】索引
数据库·mysql
jnrjian2 小时前
Hash index initrans 的修改及 partition的增
数据库·oracle
一 乐2 小时前
美食推荐|基于springboot+vue的美食分享系统设计与实现(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·美食
星环处相逢2 小时前
MySQL MHA 全解析与实战部署指南
数据库·mysql
qq_12498707532 小时前
基于springboot+vue+mysql的校园博客系统(源码+论文+部署+安装)
java·vue.js·spring boot·mysql·毕业设计