t.sale_cnt,
row_number() over(partition by pro_name order by sale_cnt desc) as rnk
from (
select
pro_name,
city_name,
sale_num,
sum(sale_num) as sale_cnt
from temp_data
group by pro_name,city_name
) t
) t1
where t1.rnk = 1
;
>
> lag: 将数据按照从小到大的顺序,将首次出现的,数据字段往后置一行,并且第一条数据使用Null填充
> lead:将数据按照从小到大的顺序,将首次出现的数据往后置一行,并且第一条数据使用Null进行填充
>
>
>
2、求股票的波峰和波谷
波峰:当天的股票价格大于前一天和后一天
波谷:当天的股票价格小于前一天和后一天
数据准备: stock表有3个字段: stock\_name(股票名称)、stock\_price(股票价格)、stats\_date(日期)
源数据:
‘A’,‘20210621’,‘13’
‘A’,‘20210622’,‘11’
‘A’,‘20210623’,‘17’
‘A’,‘20210624’,‘12’
‘A’,‘20210625’,‘14’
‘B’,‘20210621’,‘16’
‘B’,‘20210622’,‘12’
‘B’,‘20210623’,‘12’
‘B’,‘20210624’,‘17’
‘B’,‘20210625’,‘13’
结果:
stock\_name stats\_date stock\_price price\_type
A 20210621 13 其他
A 20210622 11 波谷
A 20210623 17 波峰
A 20210624 12 波谷
A 20210625 14 其他
B 20210621 16 其他
B 20210622 12 其他
B 20210623 12 其他
B 20210624 17 波峰
B 20210625 13 其他
答:
with temp\_data as (
select stack(10,
‘A’,‘20210621’,‘13’
,‘A’,‘20210622’,‘11’
,‘A’,‘20210623’,‘17’
,‘A’,‘20210624’,‘12’
,‘A’,‘20210625’,‘14’
,‘B’,‘20210621’,‘16’
,‘B’,‘20210622’,‘12’
,‘B’,‘20210623’,‘12’
,‘B’,‘20210624’,‘17’
,‘B’,‘20210625’,‘13’
) as (stock\_name,stock\_date,stock\_price)
)
select
t.stock\_name,
t.stock\_date,
t.stock\_price,
case when t.stock\_price < t.lag\_price and t.stock\_price < t.lead\_price then ‘波谷’
when t.stock\_price > t.lag\_price and t.stock\_price > t.lead\_price then ‘波峰’
else ‘其他’ end as price\_type
from (
select
stock\_name,
stock\_date,
stock\_price,
lag(stock\_price,1) over(partition by stock\_name order by stock\_date ) as lag\_price,
lead(stock\_price,1) over(partition by stock\_name order by stock\_date ) as lead\_price
from temp\_data
) t
![img](https://img-blog.csdnimg.cn/img_convert/a588803e687a9cfd04dc50b13cbacccb.png)
![img](https://img-blog.csdnimg.cn/img_convert/21400c987ef7053216677e11d11149be.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
*一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**