目录
语法
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)