在做一个投票项目,有一功能要求查出得票数前10名的票数底线。
这里用了以下SQL:
SELECT MIN(score) FROM vote_candidate WHERE score > 0 GROUP BY score ORDER BY score DESC LIMIT 10
写完后心有疑问,到底是MIN()先执行,还是LIMIT先奏效?
按以往的认识,LIMIT的优先级是排在WHERE、GROUP BY、ORDER BY之后的,是对最后返回的结果集进行限制,推测它是在聚合函数之后执行,那这个LIMIT子句就没有意义了,所得的不是预期的结果。
实践出真知,遂向表中加入一些测试数据。通过测试得出了意外的结论:
聚合函数与LIMIT子句共存时的优先级分为两种情况:
1.有GROUP BY 子句(本例):WHERE > GROUP BY > ORDER BY > LIMIT > 聚合
2.无GROUP BY 子句:WHERE > 聚合 > ORDER BY > LIMIT
时间: 2024-10-10 08:57:14