我有一张标签表,想从列表中获得计数最高的标签。
样本数据如下所示
id (1) tag ('night') id (2) tag ('awesome') id (3) tag ('night') 使用
SELECT COUNT(*), Tag
from images-tags
GROUP BY Tag
让我得到正在寻找的完美数据。但是,我想对它进行组织,以使最高的标签数排在首位,并限制它仅向我发送前20个左右。
我试过了
SELECT COUNT(id), Tag
from images-tags
GROUP BY Tag
ORDER BY COUNT(id) DESC LIMIT 20 而且我不断收到“组功能的无效使用-ErrNr 1111”
我究竟做错了什么?
我正在使用MySQL 4.1.25-Debian
问题来源于stack overflow
在所有版本的MySQL中,只需在SELECT列表中为聚合设置别名,并按别名排序:
SELECT COUNT(id) AS theCount, Tag
from images-tags
GROUP BY Tag
ORDER BY theCount DESC LIMIT 20
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。