sql查询后增加汇总的功能
  6tuRdFP5lxfF 2023年11月02日 29 0

环境

centos7,postgresql-11,mysql5.7 一般group by后统计数据后,还想算个汇总数,可以使用以下方法

postgres

使用GROUPING SETS ( ( 字段 ), ( ) )函数

SELECT
r.cmd_id,
c."name",
SUM ( r.send_count ) success,
SUM ( r.fail_count ) fail  ,
round( 100 * SUM(r.send_count) * 1.0 /  ( SUM(r.send_count)+SUM(r.fail_count) )  ) || '%' rate
FROM
run_cmd r left join  cfg_cmd c on r.cmd_id=c.id
WHERE
r.gmt_create BETWEEN '2023-7-13 10:00:00' 
AND '2023-7-13 13:00:00' 
AND ( r.send_count != 0 OR r.fail_count != 0 ) 

GROUP BY
GROUPING SETS ( ( r.cmd_id,c.name ), ( ) )
ORDER BY fail

image.png

mysql

使用WITH ROLLUP函数

SELECT
    count( 1 ),
    CellId 
FROM
    `tagreportlog` 
WHERE
    LocationTime > '2025-01-01' 
GROUP BY
    CellId WITH ROLLUP

image.png

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  D04qQxYJZ4A6   2023年11月19日   19   0   0 mysqljava读写分离
  eHipUjOuzYYH   2023年12月10日   25   0   0 mysqlsqlUser
  jnZtF7Co41Wg   2023年11月24日   23   0   0 mysqlApachecentos
  oNkSXggMkQHo   2023年11月24日   27   0   0 Dockermysql
  D04qQxYJZ4A6   2023年11月19日   34   0   0 mysqlredisphp
  9JCEeX0Eg8g4   2023年11月28日   14   0   0 主数据数据库mysql
  9JCEeX0Eg8g4   2023年12月11日   22   0   0 mysql配置文件
6tuRdFP5lxfF