当前位置: 首页 > news >正文

SQL181 第二快/慢用时之差大于试卷时长一半的试卷

描述

现有试卷信息表examination_info(exam_id试卷ID, tag试卷类别, difficulty试卷难度, duration考试时长, release_time发布时间):

试卷作答记录表exam_record(uid用户ID, exam_id试卷ID, start_time开始作答时间, submit_time交卷时间, score得分):

找到第二快和第二慢用时之差大于等于试卷时长的一半的试卷信息,按试卷ID降序排序。由示例数据结果输出如下:

exam_iddurationrelease_time
9001602021-09-01 06:00:00

解释:试卷9001被作答用时有58分钟、50分钟、30分1秒、11分钟、10分钟,第二快和第二慢用时之差为50分钟-11分钟=39分钟,试卷时长为60分钟,因此满足大于试卷时长一半的条件,输出试卷ID、时长、发布时间。

selectexam_id,duration,release_time
from(selectexam_id,duration,release_time,sum(casewhen rk_desc = 2 then time_diffwhen rk_asc = 2 then - time_diffelse 0end) as timrefrom(selecta.exam_id,timestampdiff(minute, b.start_time, b.submit_time) time_diff,a.duration,a.release_time,row_number() over (partition bya.exam_idorder bytimestampdiff(minute, b.start_time, b.submit_time) desc) as rk_desc,row_number() over (partition bya.exam_idorder bytimestampdiff(minute, b.start_time, b.submit_time) asc) as rk_ascfromexamination_info ajoin exam_record b on a.exam_id = b.exam_idwhereb.submit_time is not null) t1group byexam_id) t2
wheretimre >= (duration / 2)
order byexam_id desc;

关键 SQL 逻辑拆解

✅ 第一步:计算每位考生的答题时长(分钟)
timestampdiff(minute, start_time, submit_time) as time_diff
  • 使用 TIMESTAMPDIFF(MINUTE, ...) 计算答题持续时间。
✅ 第二步:对每场考试分别排序,找出“第二长”和“第二短”
row_number() over (partition by exam_id order by time_diff desc
) as rk_desc  -- 从长到短:最长是1,第二长是2row_number() over (partition by exam_id order by time_diff asc
) as rk_asc   -- 从短到长:最短是1,第二短是2
  • 利用窗口函数 ROW_NUMBER() 实现排名。
  • 注意:rk_desc=2 表示第二慢提交(答题时间第二长)。
✅ 第三步:条件聚合,提取“第二长 - 第二短”时间差
sum(case when rk_desc = 2 then time_diffwhen rk_asc = 2 then -time_diffelse 0 end
) as timre
  • 巧妙利用 sum(case ...) 实现“提取特定排名值”的效果。
  • 最终结果:timre = 第二长答题时间 - 第二短答题时间

💡 技巧提示:这种“条件求和”是 SQL 中实现“取第 N 值”的常用技巧。

✅ 第四步:筛选满足条件的考试
where timre >= (duration / 2)
  • 只保留差异较大的考试。
✅ 第五步:输出并排序
select exam_id, duration, release_time
order by exam_id desc
http://www.lryc.cn/news/621007.html

相关文章:

  • 【昇腾】VirtualBox虚拟机下搭建Ubuntu 22.04环境给TF卡制卡报读写IO错误的问题处理_20250814
  • 自动化测试|持续集成Git使用详解
  • elasticsearch冷热数据读写分离!
  • 快速搭建python HTTP Server测试环境
  • gitlab的ci/cd变量如何批量添加
  • STL算法【常用的算数生成算法】
  • 分享10个ai生成ppt网站(附ai生成ppt入口)
  • 力扣top100(day03-02)--图论
  • 回流(Reflow)与重绘(Repaint):浏览器渲染性能优化核心
  • SpringMVC请求与响应
  • 【Linux】库制作与原理
  • PyTorch回忆(三)U-net
  • java 学习 贪心 + 若依 + 一些任务工作
  • FTP服务器搭建(Linux)
  • opencv:傅里叶变换有什么用?怎么写傅里叶变换?
  • 软件著作权产生与登记关键点
  • 从单机到分布式:用飞算JavaAI构建可扩展的TCP多人聊天系统
  • 算法基础 第3章 数据结构
  • 数学建模-非线性规划模型
  • 深入理解提示词工程:从入门到精通的AI对话艺术
  • Mybatis实现页面增删改查
  • 数仓分层架构设计全解析:从理论到实践的深度思考
  • 一台联想 ThinkCentre M7100z一体机开机黑屏无显示维修记录
  • 【跨越 6G 安全、防御与智能协作:从APT检测到多模态通信再到AI代理语言革命】
  • 解决“Win7共享文件夹其他电脑网络无法发现共享电脑名称”的问题
  • 机器视觉之图像处理篇
  • c/c++ UNIX 域Socket和共享内存实现本机通信
  • 从概率填充到置信度校准:GPT-5如何从底层重构AI的“诚实”机制
  • 【网络安全测试】手机APP安全测试工具NowSecure 使用指导手册(有关必回)
  • PHP 开发全解析:从基础到实战的进阶之路