sql题目求助呜呜呜

假设有一个表存了1年的数据,现在想根据created_time字段统计每月的新用户数,看看哪一个月的新用户最多,

注意:created_time字段单位还是“秒”
打印方式如: 1月,xxx条;

好难呀,感觉一点思路都没有。

有没有大佬可以指点一下。万分感谢!!!
全部评论
1,用户id是主键的话按id分组 2,created_time单位是秒的话,你截取下格式到月份的,比如202006这样。 3,count(*)计算新用户,分组选月份。最后在order by 排序 4:,如果的oracle的话可以看下窗口函数,rank()over()
2 回复 分享
发布于 2020-06-24 14:05
楼上兄弟说的很明白了,我大概给你写一下select to_char(created_time,'yyyy-mm&(7995)#39;),count(user_id) ,rank()over (order by count(user_id) desc) num from table group by to_char(created_time,'yyyy-mm&(7995)#39;) 结果是每个月人数的降序 如果只要第一条就套一层 ,where条件写num = 1 多条同理 num in ()或者用between
2 回复 分享
发布于 2020-06-24 15:10
楼主把这里的题目都做一遍吧 https://www.nowcoder.com/ta/sql
1 回复 分享
发布于 2020-06-24 18:27

相关推荐

做人要有梦想dji:最新工位查看图片
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
02-14 11:10
点赞 评论 收藏
分享
评论
2
2
分享

创作者周榜

更多
牛客网
牛客企业服务