题解 | #统计每个学校的答过题的用户的平均答题数# 注意
统计每个学校的答过题的用户的平均答题数
https://www.nowcoder.com/practice/88aa923a9a674253b861a8fa56bac8e5
解法:
select university, count(b.question_id)/count(distinct b.device_id) as avg_answer_cnt from user_profile as a join question_practice_detail as b on a.device_id = b.device_id #注意 group by university #每个学校:所以按学校分组,group by university order by university
⚠️ 注意事项:
- 联结两个表:join on在ab表共有且唯一识别的device_id
- 计算平均答题数量:在每个学校的分组内,
count(question_id) / count(distinct device_id)
,要注意用
count(distinct...)
对登录设备id去重
【由于存在一个设备id多次登录的情况】 - 每个学校:按学校分组,
group by university