欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 手游 > 【SQL】连续出现的数字

【SQL】连续出现的数字

2024/10/24 22:22:20 来源:https://blog.csdn.net/weixin_73404807/article/details/142897022  浏览:    关键词:【SQL】连续出现的数字

目录

语法

需求

示例

分析

代码


语法

SELECT column_name(s)

FROM table_name

WHERE column_name IN (value1, value2, ...);

WHERE column_name IN (value1, value2, ...);是 SQL 中用于过滤查询结果的一种条件语句,它允许从一个给定的值列表中选择匹配的行。

  • column_name(s):要选择的列名,可以是单个列名或多个列名(用逗号分隔)。
  • table_name:要查询的表的名称。
  • column_name:用于匹配的值所在的列名。
  • (value1, value2, ...):一个包含多个值的列表,这些值用于与 column_name 中的值进行比较。

当需要从一个列中选择具有特定值的行时,可以使用 WHERE IN 语法。例如,选择所有国家为“USA”、“India”和“China”的产品。与多个 OR 条件相比,WHERE IN 语法可以使查询更加简洁和易读。例如,选择所有名称以“Mac”开头的产品,虽然这通常使用 LIKE 运算符,但 IN 语法在处理精确匹配时更加直观。

需求

表:Logs

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| num         | varchar |
+-------------+---------+
在 SQL 中,id 是该表的主键。
id 是一个自增列。

找出所有至少连续出现三次的数字。

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

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

示例

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

分析

找出所有至少连续出现三次的数字

单纯面向题目,三表连接或者子查询均可以实现

where in 找到id连续三次的数字

即(id,num)中id+1,+2,num不变

where (id+1,num) in (select * from Logs)

and (id+2,num) in (select * from Logs)

可能检索到同一数字

通过distinct每个数字仅取一次,select distinct num as ConsecutiveNums

代码

select distinct num as ConsecutiveNums
from Logs
where (id+1,num) in (select * from Logs)
and (id+2,num) in (select * from Logs)

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com