题解 | #统计每个学校各难度的用户平均刷题数#

统计每个学校各难度的用户平均刷题数

https://www.nowcoder.com/practice/5400df085a034f88b2e17941ab338ee8

select university,difficult_level,count(question.question_id) / count(distinct question.device_id) avg_answer_cnt from user_profile user  join question_practice_detail  question on user.device_id = question.device_id  join question_detail detail on question.question_id =  detail.question_id group by university,difficult_level
  1. 不同学校、不同难度,即需要使用group by进行分组
  2. 用户平均答题数量,需要考虑一个用户可以重复答题,因此使用 题目总数/去重后的用户设备总数
  3. 注意使用inner join而不是left join,原因是题目中要求参加了答题的用户,即有些用户可能没有答题,因此使用inner
全部评论
本题可以使用left join,但需要注意以哪张表作为基表使用
点赞 回复 分享
发布于 2023-01-30 22:56 陕西

相关推荐

1jian10:48h没写面评会变成这样
点赞 评论 收藏
分享
不知名bang:感觉三个项目可以融在一起,比如上层是用手写的epoll,然后到tcp聊天层,然后你写了一个后台监控(不过我也不懂c++,但是感觉写一个大项目比三个小项目要好)
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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