MySQL 聚合函数与LIMIT

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL 聚合函数与LIMIT相关的知识,希望对你有一定的参考价值。

在做一个投票项目,有一功能要求查出得票数前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的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL

3.1.3MySQL__数据库基本建表查询,登录,sql语句,建表语句,修改表结构,增删改查,as别名,limit分页,distinct去重,聚合函数,

1-1MySql复习

微信小程序云开发 云函数阶段聚合Aggregate阶段,突破limit为20的限制,使获取数量可以无限

微信小程序云开发 云函数阶段聚合Aggregate阶段,突破limit为20的限制,使获取数量可以无限

TOP 函数的工作方式与 mysql 中的 LIMIT 不同吗?