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

本文介绍了如何利用withas和临时表在SQL查询中解决LeetCode题目601,关注如何确定连续的三行或多行记录,通过withas创建临时表并结合row_number函数实现高效查询。特别强调了SQL的运行顺序和Hive中的临时空间使用技巧。

前述

知识点学习:

  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 Sta
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值