MySQL SUM() COUNT()

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

如题MySQL SUM() COUNT() 也是在工作中碰到的 特此记录一下

SUM()返回的是列的数字和 如一个学生的总分数

eg:select sum(obj) from table 返回的肯定是table表中 obj列的数字之和

COUNT() 计算指定列的个和 如一个学生的不及格科目几科

eg:select count(*) from table 返回的肯定是table表中有多少行 null是被忽略的

sum经常和group by一起使用 count经常和distinct使用 


比如下边的这个学生表

ysql> show create table SC\G
*************************** 1. row ***************************
       Table: SC
Create Table: CREATE TABLE `SC` (
  `Sid` varchar(10) DEFAULT NULL,
  `Cid` varchar(10) DEFAULT NULL,
  `score` decimal(18,1) DEFAULT NULL,
  KEY `Sid` (`Sid`),
  KEY `Cid` (`Cid`),
  CONSTRAINT `SC_ibfk_1` FOREIGN KEY (`Sid`) REFERENCES `Student` (`Sid`),
  CONSTRAINT `SC_ibfk_2` FOREIGN KEY (`Cid`) REFERENCES `Course` (`Cid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql> select * from SC;
+------+------+-------+
| Sid  | Cid  | score |
+------+------+-------+
| 01   | 01   |  80.0 |
| 01   | 02   |  90.0 |
| 01   | 03   |  99.0 |
| 02   | 01   |  70.0 |
| 02   | 02   |  60.0 |
| 02   | 03   |  80.0 |
| 03   | 01   |  80.0 |
| 03   | 02   |  80.0 |
| 03   | 03   |  80.0 |
| 04   | 01   |  50.0 |
| 04   | 02   |  30.0 |
| 04   | 03   |  20.0 |
| 05   | 01   |  76.0 |
| 05   | 02   |  87.0 |
| 06   | 01   |  31.0 |
| 06   | 03   |  34.0 |
| 07   | 02   |  89.0 |
| 07   | 03   |  98.0 |
+------+------+-------+
18 rows in set (0.01 sec)

mysql> 

统计一下成绩不及格的Sid及总成绩

1 select sid,sum(score) from SC where score < 60 group by sid ;

2 select sid,count(score) from SC where score < 60 group by sid;

执行结果:


mysql> select sid,sum(score) from SC where score < 60 group by sid;
+------+------------+
| sid  | sum(score) |
+------+------------+
| 04   |      100.0 |
| 06   |       65.0 |
+------+------------+
2 rows in set (0.03 sec)

mysql> select sid,count(score) from SC where score < 60 group by sid;
+------+--------------+
| sid  | count(score) |
+------+--------------+
| 04   |            3 |
| 06   |            2 |
+------+--------------+
2 rows in set (0.00 sec)

mysql> 
也就是说 下面可以看出区别

Sum()函数里面的参数是列名的时候 是计算列名的值的相加 

Count()函数里面的参数是列名的的时候,那么会计算有值项的次数 

mysql> select sid,sum(score < 60) from SC group by sid;
+------+-----------------+
| sid  | sum(score < 60) |
+------+-----------------+
| 01   |               0 |
| 02   |               0 |
| 03   |               0 |
| 04   |               3 |
| 05   |               0 |
| 06   |               2 |
| 07   |               0 |
+------+-----------------+
7 rows in set (0.01 sec)

mysql> select sid,count(score < 60) from SC group by sid;   
+------+-------------------+
| sid  | count(score < 60) |
+------+-------------------+
| 01   |                 3 |
| 02   |                 3 |
| 03   |                 3 |
| 04   |                 3 |
| 05   |                 2 |
| 06   |                 2 |
| 07   |                 2 |
+------+-------------------+
7 rows in set (0.02 sec)

mysql> 


本文转自 aklaus 51CTO博客,原文链接:http://blog.51cto.com/aklaus/1597488

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
344
分享
相关文章
MySQL的count()方法慢
MySQL的 `COUNT()`方法在处理大数据量时可能会变慢,主要原因包括数据量大、缺乏合适的索引、InnoDB引擎的设计以及复杂的查询条件。通过创建合适的索引、使用覆盖索引、缓存机制、分区表和预计算等优化方案,可以显著提高 `COUNT()`方法的执行效率,确保数据库查询性能的提升。
940 12
MySQL常用函数:IF、SUM等用法
本文介绍了MySQL中常用的IF、SUM等函数及其用法,通过具体示例展示了如何利用这些函数进行条件判断、数值计算以及复杂查询。同时,文章还提到了CASE WHEN语句和其他常用函数,如COUNT、AVG、MAX/MIN等,强调了它们在数据统计分析、数据清洗和报表生成中的重要性。
MySQL战记:Count( *)实现之谜与计数策略的选择
本文深入探讨了MySQL中`count(*)`的不同实现方式,特别是MyISAM和InnoDB引擎的区别,以及各种计数方法的性能比较。同时,文章分析了使用缓存系统(如Redis)与数据库保存计数的优劣,并强调了在高并发场景下保持数据一致性的挑战。
141 0
MySQL战记:Count( *)实现之谜与计数策略的选择
MySQL性能探究:count(*)与count(1)的性能对决
在MySQL数据库的性能优化中,对查询语句的细微差别有着深入的理解是非常重要的。`count(*)`和`count(1)`是两种常用的聚合函数,用于计算行数。在面试中,面试官经常会问到这两种函数的性能差异。本文将探讨`count(*)`与`count(1)`的性能对比,并整理十道经典的MySQL面试题,帮助你在面试中游刃有余。
196 3
MySQL的group by与count(), *字段使用问题
正确使用 `GROUP BY`和 `COUNT()`函数是进行数据聚合查询的基础。通过理解它们的用法和常见问题,可以有效避免查询错误和性能问题。无论是在单列分组、多列分组还是结合其他聚合函数的场景中,掌握这些技巧和注意事项都能大大提升数据查询和分析的效率。
484 0
深度剖析:MySQL聚合函数 count(expr) 如何工作?如何选择?
本文详细探讨了MySQL中count(expr)函数的不同形式及其执行效率,包括count(*)、count(1)、count(主键)、count(非主键)等。通过对InnoDB和MyISAM引擎的对比分析,解释了它们在不同场景下的实现原理及性能差异。文章还通过实例演示了事务隔离级别对统计结果的影响,并提供了源码分析和总结建议。适合希望深入了解MySQL统计函数的开发者阅读。
96 0
Mysql中count(1)、count(*)以及count(列)的区别
Mysql中count(1)、count(*)以及count(列)的区别
126 0
Mysql COUNT() 函数详解
【6月更文挑战第19天】Mysql COUNT() 函数详解,包括 COUNT() 的用法及 COUNT() 带条件查询的操作
MySQL设计规约问题之为什么统计表中记录数时推荐使用COUNT(*)而不是COUNT(primary_key)或COUNT(1)
MySQL设计规约问题之为什么统计表中记录数时推荐使用COUNT(*)而不是COUNT(primary_key)或COUNT(1)
MySQL数据库——SQL优化(3/3)-limit 优化、count 优化、update 优化、SQL优化 小结
MySQL数据库——SQL优化(3/3)-limit 优化、count 优化、update 优化、SQL优化 小结
354 0