SQL 在使用 GROUP BY 进行归类汇总的时候直接获取总数

SQL 中我们一般使用 GROUP BY 进行归类汇总,比如微信机器人高级版对消息类型中进行汇总的 SQL 为:

SELECT COUNT( * ) AS count, MsgType FROM wp_weixin_messages GROUP BY MsgType

如果按照数量排序:

SELECT COUNT( * ) AS count, MsgType FROM wp_weixin_messages GROUP BY MsgType ORDER BY count DESC

如果要计算每种类型的比例,又要使用一条新的 SQL 到数据库里面查询一次,有没有办法在使用 GROUP BY 进行归类汇总的时候直接获取总数,查询了下 MySQL 的说明文档,我们可以使用 WITH ROLLUP。

SELECT COUNT( * ) AS count, MsgType FROM wp_weixin_messages GROUP BY MsgType WITH ROLLUP

这样获取的一个字段就是总数,但是名称(MsgType)为 null,我们把他设置为 total。

SELECT COUNT( * ) AS count, IFNULL( MsgType,  'total' ) AS MsgType FROM wp_weixin_messages GROUP BY MsgType WITH ROLLUP

但是使用 WITH ROLLUP 有个不好的地方,不能在进行 ORDER BY 了。


©我爱水煮鱼,本站推荐使用的主机:阿里云,国外主机建议使用BlueHost

本站长期承接 WordPress 优化建站业务,要求很高,有兴趣请联系微信:「chenduopapa」或微信公众号:「WordPress果酱」。

标签: MySQL

热门文章