码迷,mamicode.com
首页 > 数据库 > 详细

MySQL 聚合函数与LIMIT

时间:2016-11-16 11:18:08      阅读:765      评论:0      收藏:0      [点我收藏+]

标签:测试   font   select   没有   通过   core   des   情况   esc   

在做一个投票项目,有一功能要求查出得票数前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

MySQL 聚合函数与LIMIT

标签:测试   font   select   没有   通过   core   des   情况   esc   

原文地址:http://www.cnblogs.com/haries/p/6068569.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!