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

复制代码
select 
        u.university,qd.difficult_level,
        round(count(qpd.question_id)/count(distinct qpd.device_id),4) avg_answer_cnt
from
        user_profile u
inner join 
        question_practice_detail qpd
on
        u.device_id=qpd.device_id
inner join
        question_detail qd
on
        qpd.question_id=qd.question_id
group by
        university,difficult_level;

🔹 SELECT 子句

  • u.university:从用户表 user_profile 中取出学校名称
  • qd.difficult_level:从题目表 question_detail 中取出题目难度
  • ROUND(..., 4):把计算结果四舍五入保留四位小数
  • COUNT(qpd.question_id``):统计所有被用户做过的题目总次数(即刷题总数)
  • COUNT(DISTINCT qpd.device_id):统计该分组下的独立用户数(避免同一个用户多次刷题被重复计算)
  • AS avg_answer_cnt:给计算结果起一个别名,叫 "平均答题数"(as省略)

🔹 FROM & JOIN 子句

  • FROM user_profile u:从用户信息表开始查询,并给表起别名 u
  • JOIN question_practice_detail qpd ON u.device_id = qpd.device_id:通过 device_id(用户唯一标识)把用户表和答题记录表关联起来,这样就能知道每个用户做了哪些题
  • JOIN question_detail qd ON qpd.question_id = qd.question_id:通过 question_id(题目唯一标识)把答题记录表和题目详情表关联起来,这样就能知道每道题的难度

🔹 GROUP BY子句

  • GROUP BY:按照学校题目难度 对数据进行分组,这样后续的聚合计算(COUNT)就会在每个分组内独立进行
相关推荐
炘爚6 分钟前
深入解析printf缓冲区与fork进程复制机制
linux·运维·算法
迈巴赫车主1 小时前
蓝桥杯19724食堂
java·数据结构·算法·职场和发展·蓝桥杯
C'ᴇsᴛ.小琳 ℡1 小时前
高性能NoSQL
数据库·nosql
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 78. 子集 | C++ 回溯算法题解
c++·算法·leetcode
Kethy__1 小时前
计算机中级-数据库系统工程师-数据结构-查找算法
数据结构·算法·软考·查找算法·计算机中级
所以遗憾是什么呢?1 小时前
【题解】Codeforces Round 1081 (Div. 2)
数据结构·c++·算法·acm·icpc·ccpc·xcpc
i220818 Faiz Ul2 小时前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
iNgs IMAC2 小时前
redis 使用
数据库·redis·缓存
xiaoye-duck3 小时前
《算法题讲解指南:递归,搜索与回溯算法--综合练习》--14.找出所有子集的异或总和再求和,15.全排列Ⅱ,16.电话号码的字母组合,17.括号生成
c++·算法·深度优先·回溯
OOJO3 小时前
c++---vector介绍
c语言·开发语言·数据结构·c++·算法·vim·visual studio