【SQL】601. 体育馆的人流量(with as 临时表;id减去row_number()思路)

64 篇文章 1 订阅

前述

知识点学习:

  1. with as 和临时表的使用
  2. 12、关于临时表和with as子查询部分

题目描述

leetcode题目:601. 体育馆的人流量

在这里插入图片描述
在这里插入图片描述

思路

关键:如何确定id是连续的三行或更多行记录

  • 方法一: 多次连表,筛选查询
  • 方法二: 借助 with as 临时表,id - row_number() over (order by id) as rk (俺这菜鸡没想到 id-row_number(),手动狗头)就能分成如下图:
    在这里插入图片描述
    【图片引自题解

写法一:join

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 and t2.id - t3.id = 1) or 
    (t2.id - t1.id = 1 and t2.id - t3.id = 2 and t1.id - t3.id = 1) or
    (t3.id - t2.id = 1 and t2.id - t1.id = 1 and t3.id - t1.id = 2)
)
order by t1.id;

写法二:with as 临时空间

在公司用hive常会用到这解法,有时候会在临时表里再多重嵌套

这道题需要提前用With临时空间,是因为where子句中需要再次调用from中选取的表
这里再聊一下sql的运行顺序:
from -> where -> group by -> select -> order by -> limit
即临时表t1 在from 和 where 中都会用到,因此需要提前定义。【引用题解 ,推荐阅读】

with t1 as (
    select *,
    id - row_number() over (order by id) as rk
    from Stadium
    where people >= 100
)

select id, visit_date, people
from t1 
where rk in (
    select rk 
    from t1
    group by rk
    having count(rk) >= 3
);

部分过程解析:

在这里插入图片描述

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值