题解 | #SQL类别高难度试卷得分的截断平均值#

SQL类别高难度试卷得分的截断平均值

http://www.nowcoder.com/practice/a690f76a718242fd80757115d305be45

题目要求计算截断平均值,去掉一个最大值和一个最小值而非去掉极值,故可以用窗口函数row_number()over()对成绩进行排序,我这里先筛选出SQL类别高难度试卷按成绩升序排序和降序排序的表组成一个新表,继而再从新表中SELECT出截断平均值。 一开始我没有加GROUP BY函数,运行时出现了一个bug: alt 也就是说,mysql的sql_mode是only_full_group_by的时候,在不使用group by 并且select后面出现聚集函数的话,那么所有被select的都应该是聚集函数,否则就会报错。果不其然,我后面加上group by便运行通过了。

SELECT tag, difficulty, ROUND(AVG(score) ,1) as clip_avg_score
FROM (
    SELECT tag, difficulty, score, 
           ROW_NUMBER()OVER(ORDER BY score ASC) as rank1,
           ROW_NUMBER()OVER(ORDER BY score DESC) as rank2
    FROM examination_info JOIN exam_record USING(exam_id)
    WHERE tag = 'SQL' AND difficulty = 'hard' AND score IS NOT NULL
) t
WHERE t.rank1 >= 2 AND t.rank2 >= 2
GROUP BY tag, difficulty
全部评论

相关推荐

10-22 15:25
门头沟学院 C++
种花网友小松:求求你别发了,我几乎都快嫉妒得疯了,倒在床上蒙住被子就开始抱着枕头尖叫流泪,嘴里一边喊着卧槽卧槽,一边又忍着,我边发边哭,打字的手都是抖的,后来我的手抖得越来越厉害,从心头涌起的思想、情怀和梦想,这份歆羡和悔恨交织在一起,我的笑还挂在脸上,可是眼泪一下子就掉下来了。求你了别发了,我生活再难再穷我都不会觉得难过,只有你们发这种东西的时候,我的心里像被刀割一样的痛,打着字泪水就忍不住的往下流。
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务