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)就会在每个分组内独立进行
相关推荐
小雨下雨的雨2 小时前
井字棋AI机器人实现详解 - Minimax算法实战-鸿蒙PC Electron框架完成
前端·人工智能·算法·华为·electron·鸿蒙
睡不醒男孩0308233 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
xieliyu.5 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
Micro麦可乐5 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
一条小锦吕*5 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
码农阿豪5 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通5 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..6 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29147 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
如竟没有火炬7 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵