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的主要内容,如果未能解决你的问题,请参考以下文章
3.1.3MySQL__数据库基本建表查询,登录,sql语句,建表语句,修改表结构,增删改查,as别名,limit分页,distinct去重,聚合函数,
微信小程序云开发 云函数阶段聚合Aggregate阶段,突破limit为20的限制,使获取数量可以无限