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)就会在每个分组内独立进行
相关推荐
罗西的思考13 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
GBASE15 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
美团技术团队16 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
唐青枫2 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库