题目

image.png

image.png

备注:保证至少有一个有效的SQL类别的试卷作答分数

建表语句

  1. drop table if exists examination_info;
  2. CREATE TABLE examination_info (
  3. id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
  4. exam_id int UNIQUE NOT NULL COMMENT '试卷ID',
  5. tag varchar(32) COMMENT '类别标签',
  6. difficulty varchar(8) COMMENT '难度',
  7. duration int NOT NULL COMMENT '时长',
  8. release_time datetime COMMENT '发布时间'
  9. )CHARACTER SET utf8 COLLATE utf8_general_ci;
  10. drop table if exists exam_record;
  11. CREATE TABLE exam_record (
  12. id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
  13. uid int NOT NULL COMMENT '用户ID',
  14. exam_id int NOT NULL COMMENT '试卷ID',
  15. start_time datetime NOT NULL COMMENT '开始时间',
  16. submit_time datetime COMMENT '提交时间',
  17. score tinyint COMMENT '得分'
  18. )CHARACTER SET utf8 COLLATE utf8_general_ci;
  19. INSERT INTO examination_info(exam_id,tag,difficulty,duration,release_time) VALUES
  20. (9001, 'SQL', 'hard', 60, '2020-01-01 10:00:00'),
  21. (9002, 'SQL', 'easy', 60, '2020-02-01 10:00:00'),
  22. (9003, '算法', 'medium', 80, '2020-08-02 10:00:00');
  23. INSERT INTO exam_record(uid,exam_id,start_time,submit_time,score) VALUES
  24. (1001, 9001, '2020-01-02 09:01:01', '2020-01-02 09:21:01', 80),
  25. (1002, 9001, '2021-09-05 19:01:01', '2021-09-05 19:40:01', 89),
  26. (1002, 9002, '2021-09-02 12:01:01', null, null),
  27. (1002, 9003, '2021-09-01 12:01:01', null, null),
  28. (1002, 9001, '2021-02-02 19:01:01', '2021-02-02 19:30:01', 87),
  29. (1002, 9002, '2021-05-05 18:01:01', '2021-05-05 18:59:02', 90),
  30. (1003, 9002, '2021-02-06 12:01:01', null, null),
  31. (1003, 9003, '2021-09-07 10:01:01', '2021-09-07 10:31:01', 86),
  32. (1004, 9003, '2021-09-06 12:01:01', null, null);

解题思路

读取题目大意:

  • 从试卷作答记录表中找到类别为的SQL试卷得分不小于该类试卷平均得分的用户最低得分
  • 其中试卷信息记录在表examination_info(包括试卷ID、类别、难度、时长、发布时间),答题信息记录在表exam_record(包括试卷ID、用户ID、开始时间、结束时间、得分)

问题拆分:

  • 要找类别为SQL的试卷平均得分:
    • 得分信息在exam_record,试卷类别在表examination_info中,因此要将两个表以exam_id连接。知识点:join…on…
    • 从连接后的表中找到类别为SQL的试卷的分数。知识点:select…from…where…
    • 计算得分的平均值。知识点:avg()
  • 找到类别SQL的试卷得分大于平均得分的最小值:
    • 得分信息在exam_record,试卷类别在表examination_info中,因此要将两个表以exam_id连接。知识点:join…on…
    • 从连接后的表中找到类别为SQL的试卷且分数大于刚刚找到的平均分的分数。知识点:select…from…where…and…
    • 从中选出最小值。知识点:min()

SQL代码

select min(e_r.score) as min_score_over_avg
from exam_record e_r join examination_info e_i
on e_r.exam_id = e_i.exam_id
where e_i.tag = 'SQL'
and score >= (select avg(e1.score)
             from exam_record e1 join examination_info e2
             on e1.exam_id = e2.exam_id
             where tag = 'SQL'
             )