Leetcode之mysql专题《Human Traffic of Stadium》

本文介绍了一个SQL查询案例,目标是从体育场的人流数据中筛选出连续3天或以上,每日参观人数超过100人的记录。通过自连接三次相同的数据表,并设定特定的日期和ID条件,确保了查询结果的准确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目内容如下(链接:https://leetcode.com/problems/human-traffic-of-stadium/submissions/1

X city built a new stadium, each day many people visit it and the stats are saved as these columns: iddatepeople

Please write a query to display the records which have 3 or more consecutive rows and the amount of people more than 100(inclusive).

For example, the table stadium:

+------+------------+-----------+
| id   | date       | people    |
+------+------------+-----------+
| 1    | 2017-01-01 | 10        |
| 2    | 2017-01-02 | 109       |
| 3    | 2017-01-03 | 150       |
| 4    | 2017-01-04 | 99        |
| 5    | 2017-01-05 | 145       |
| 6    | 2017-01-06 | 1455      |
| 7    | 2017-01-07 | 199       |
| 8    | 2017-01-08 | 188       |
+------+------------+-----------+

For the sample data above, the output is:

+------+------------+-----------+
| id   | date       | people    |
+------+------------+-----------+
| 5    | 2017-01-05 | 145       |
| 6    | 2017-01-06 | 1455      |
| 7    | 2017-01-07 | 199       |
| 8    | 2017-01-08 | 188       |
+------+------------+-----------+

Note:
Each day only have one row record, and the dates are increasing with id increasing.

题解思路如下:

1. 题目要求找出最近连续3天或以上人数超过100的记录,解决方法比较简单,就关联3个相同的表t1、t2、t3,过滤掉人数小于100的记录之后,满足下面3个条件之一即可:

(1) t1.id>t2.id>t3.id 且相邻2者差距为1天

(2) t3.id>t1.id>t2.id 且相邻2者差距为1天

(3) t3.id>t2.id>t1.id 且相邻2者差距为1天

注意最后要对结果进行去重

2. 汇总一下即可得到问题的答案如下

SELECT
    DISTINCT t1.*
FROM
    stadium t1, stadium t2, stadium t3
WHERE
    t1.people >= 100 AND t2.people >= 100 AND t3.people >= 100 AND(
        (t1.id - t2.id = 1 AND t1.id - t3.id = 2) OR
        (t1.id - t2.id = 1 AND t3.id - t1.id = 1) OR
        (t2.id - t1.id = 1 AND t3.id - t1.id = 2)
    )
ORDER BY t1.id;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值