Mysql——SUM()函数

目录

一、前期准备工作

新建表如下:

插入的数据如下:

二、SUM()函数的用法 

1.求和,返回指定列的总和

SUM 函数可以对单个列求和,也可以对多个列运算后求和,计算中忽略 NULL 值

SUM函数与分组 GROUP  BY 使用,可以分组求和

SUM对多个列运算后求和,如果运算的列中有个字段为 NULL, 运算结果也为 NULL

在没有符合条件的数据时使用 SUM 函数,则 SUM 函数返回 NULL,而不是 0

可以通过结合使用 IFNULL 或 COALESCE 函数来解决结果为 NULL 的情况

2.SUM()可以求总记录数

1.SUM(1)相当于COUNT(1)

2.求符合条件的记录数

3.使用如果表达式IF(expr, v1, v2), expr 成立,返回结果 v1;否则,返回结果 v2

3.使用条件表达式


一、前期准备工作

本文基于自己的理解,总结了 SUM() 函数的用法。为了更加直观,我先新建一个 student_table 表并往表里面插入一些数据,方便后面的 sql 举例。如有错误,还请指出。

新建表如下:

CREATE TABLE `student_table` (
  `id` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '主键',
  `name` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '姓名',
  `gender` int DEFAULT '0' COMMENT '性别 0:保密 1:男 2:女',
  `id_card` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '身份证号',
  `national` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '民族',
  `phone` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '联系电话',
  `score` decimal(10,2) DEFAULT NULL COMMENT '期末总分数',
  `describe` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '描述',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='学生表';

插入的数据如下:

insert into student_table values(1,'小明','1','111222333444555666','汉族','11122233344','8','zxcvbnm');  
insert into student_table values(2,'红红','2','999999999444444444','汉族','99999444444','7','sfsdvsvs');  
insert into student_table values(3,'张三','0','666666666888888888','苗族','66666688888','8','gsfwwsfg');  
insert into student_table values(4,'李四','0','111111111444444444','苗族','11111144444','6','erefsss');  
insert into student_table values(5,'王五','0','333333333777777777','苗族','33333377777','4','lkjgdgsgssftg');  
insert into student_table values(6,'小绿',NULL,NULL,NULL,NULL,NULL,NULL);
insert into student_table values(7,NULL,NULL,NULL,NULL,NULL,NULL,NULL);


二、SUM()函数的用法 

1.求和,返回指定列的总和

1.

SUM 函数可以对单个列求和,也可以对多个列运算后求和,计算中忽略 NULL 值(如果运算的列中有个字段为 NULL, 运算结果也为 NULL)

SUM函数与分组 GROUP  BY 使用,可以分组求和

SUM函数与分组 GROUP  BY 使用:SUM对多个列运算后求和,如果运算的列中有个字段为 NULL, 运算结果也为 NULL

(最后一个结果为null: id 不为 NULL,但是 score 为 NULL ,运算的结果也为 NULL )

2.

在没有符合条件的数据时使用 SUM()函数,或者当某一列全是NULL时,则 SUM()函数返回 NULL,而不是 0

可以通过结合使用 IFNULL 或 COALESCE 函数来解决结果为 NULL 的情况

IFNULL 函数语法:

  • IFNULL 函数接受两个参数,如果第一个参数不是 null 会直接返回,如果第一个参数是 null ,则返回第二个参数
  • IFNULL(expression, alt_value)
  • expression:需要检查是否为null的字段名或者表达式。
  • alt_value:如果expression的值是null,则返回的备用值。

        简单说就是:expression为null时取alt_value

COALESCE 函数语法:

  • COALESCE 函数可以接受两个或多个参数,并返回第一个非 null 的参数,如果所有参数都为 null,则会返回 null
  • COALESCE ( f1, f2, f3, ... fn)

    COALESCE 用于:f1有值,返回f1,若为null,则看f2,f2有值,则返回f2,若为null,继续往后。以此类推。

    简单说就是:f1若为null,则取f2,f2若为null,则取f3,以此类推。

2.SUM()可以求总记录数

1.SUM(1)相当于COUNT(1)

count(1):统计所有的记录(包括null)。当使用sum(1)时与count(*)相同,都是返回当前条件的记录数,但count效率会高点。

2.求符合条件的记录数

3.使用如果表达式:IF(expr, v1, v2)

expr 成立,返回结果 v1;否则,返回结果 v2

sum(true)  等同于 sum(1)

分数大于或等于 5 的返回 2 

分数大于或等于 9 的返回 true

3.使用条件表达式

CASE
WHEN 条件1 THEN 选项1
WHEN 条件2 THEN 选项2
……
ELSE 默认值
END

当score大于等于5时取1否则取0

当score大于等于9时取1否则取0

  • 39
    点赞
  • 117
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中,SUM函数是用来计算某一列的总和的。然而,SUM函数本身并不会使用索引,因为它需要扫描整个表来计算总和。对于SUM函数的索引优化,有以下几点可以考虑: 1. 建立涵盖索引:可以为包含SUM计算的列和其他需要的列建立一个涵盖索引。涵盖索引是一个包含了查询所需的所有列的索引,这样查询可以直接从索引中获取数据,而不需要回表读取数据行。 2. 使用汇总表:可以创建一个汇总表,将SUM计算的结果存储在汇总表中,并使用触发器或定时任务来保持汇总表的数据与源表同步。在查询时,可以直接从汇总表中获取SUM计算的结果,而不需要扫描整个表。 3. 使用分区表:如果数据量非常大,可以考虑将表进行分区,并在分区表上创建索引。这样可以将计算过程分散到多个分区上,提高计算效率。 需要注意的是,以上方法仅适用于某些特定情况下的优化,并不是通用的方法。在具体情况中,还需要考虑表的大小、数据的分布情况、查询的频率等因素,以选择合适的优化方案。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Mysql——》索引的创建与使用](https://blog.csdn.net/weixin_43453386/article/details/124518403)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【2.21】MySQL索引、动态规划、学习方法](https://blog.csdn.net/weixin_62633072/article/details/129150005)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值