题解 | #每篇文章同一时刻最大在看人数#

每篇文章同一时刻最大在看人数

http://www.nowcoder.com/practice/fe24c93008b84e9592b35faa15755e48

第一次做到这个类型的题目,一定要收藏一下。 本题的关键点: 1一个时间戳表格,记录每个时间点读者的行为, 2同时根据题目先进后出,对sign进行降序排序 3搭配sum + 窗口函数(order by)是累计和,这也是关键点

select artical_id,max(uv) as max_uv
from (
select artical_id,time,sum(sign) over(partition by artical_id  order by time ,sign desc) as uv
FROM
(select artical_id,in_time as time ,1 as sign
from tb_user_log log1 where artical_id!=0
union all
select artical_id,out_time as time ,-1 as sign
from tb_user_log log1 where artical_id!=0) tmp

order by artical_id,time,sign desc
) tmp2
group by artical_id
order by max_uv DESC
全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
陆续:不可思议 竟然没那就话 那就我来吧 :你是我在牛客见到的最美的女孩
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务