牛客网SQL160

国庆期间每类视频点赞量和转发量_牛客题霸_牛客网

sql 复制代码
select *
from
(
select tag,dt,
sum(单日点赞量)over(partition by tag order by dt rows between 6 preceding and 0 following),
max(单日转发量)over(partition by tag order by dt rows between 6 preceding and 0 following)
from
(
select dt,tag,sum(if_like) 单日点赞量,sum(if_retweet) 单日转发量
from
(
    select id,video_id,if_like,if_retweet,
    date_format(start_time,'%Y-%m-%d') dt
    from tb_user_video_log
    where date_format(start_time,'%Y-%m-%d') between '2021-09-25' and '2021-10-03'
) a
join
(
    select video_id,tag
    from tb_video_info
) b
on a.video_id=b.video_id
group by dt,tag
) c
) d
where dt between '2021-10-01' and '2021-10-03'
order by tag desc,dt

注意点:

  1. date_format中%Y和%y好像不一样 ;

  2. 注意时间相关的函数,如果想当成数字取用要注意是不是带"-"的,小细节问题,如果带"-",你和数字直接去比较肯定不一样。

比较的时候一般用between and比较多

  1. 认识了mysql中三个时间相关的函数:

convert(start_time,char(10))

date_format(start_time,'%Y-%m-%d')

date(start_time)

结果都是2021-09-25的格式

相关推荐
在风中的意志4 分钟前
[数据库SQL] [leetcode-183] 183. 从不订购的客户
数据库·sql
在风中的意志1 小时前
[数据库SQL] [leetcode-197] 197. 上升的温度
数据库·sql
鸽芷咕2 小时前
告别适配难题:Oracle 迁移 KingbaseES SQL 语法快速兼容方案
数据库·sql·oracle·金仓数据库
短剑重铸之日9 小时前
7天读懂MySQL|Day 5:执行引擎与SQL优化
java·数据库·sql·mysql·架构
雨中飘荡的记忆15 小时前
MyBatis SQL执行模块详解
数据库·sql·mybatis
lbb 小魔仙20 小时前
【Java】Spring Data JPA 详解:ORM 映射、查询方法与复杂 SQL 处理
java·开发语言·sql·spring cloud
越甲八千1 天前
SQL注入
数据库·sql·oracle
夜光小兔纸1 天前
Oracle 表新增 ID RAW(16) 字段并填充历史数据
数据库·sql·oracle
七夜zippoe1 天前
MyBatis插件开发-实现SQL执行耗时监控
java·sql·mybatis·springboot·责任链
爱好读书1 天前
AI+SQL生成ER图
数据库·人工智能·sql