![SQL基础教程(视频教学版)](https://wfqqreader-1252317822.image.myqcloud.com/cover/368/27563368/b_27563368.jpg)
4.3 使用聚合函数查询
有时候并不需要返回实际表中的数据,而只是对数据进行汇总。MySQL提供了一些聚合函数,可以对查询的数据进行分析和报告。这些函数的功能有计算数据表中记录的总条数(或总行数),计算某个字段中数据的总和,以及计算数据表中某个字段中的最大值、最小值或者平均值。本节将介绍这些函数,这些聚合函数的名称和作用如表4.2所示。
表4.2 MySQL聚合函数
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-T133_55798.jpg?sign=1738900698-HjnUbqzXfzljuXwyYuA71I1p7KL3ANcB-0-42f399af4f478d6c83b8b68d7621fe4d)
接下来,将详细介绍各个函数的使用方法。
4.3.1 COUNT()函数
COUNT()函数统计数据表中包含的记录总条数(或总行数),或者根据查询结果返回记录的行数。它的使用方法有两种:
- COUNT(*):计算数据表中总的行数,不管某字段有数值或者为空值。
- COUNT(字段名):计算指定字段(或指定列)的总行数,计算时将忽略空值的行。
【例4.34】查询customers表中记录的总行数,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P133_55799.jpg?sign=1738900698-KjqmMMq5WaPt5GflHibL070yLXl2XLbj-0-09f63fb8c9210f46d056d9a060f6cda6)
从查询结果可以看到,COUNT(*)返回customers表中记录的总行数,不管其值是什么,返回的总行数的名称为cust_num。
【例4.35】查询customers表中有电子邮箱的顾客的总数,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P133_55800.jpg?sign=1738900698-81P1ypunALz6J4D0I2nlr0D3XHRzzbwk-0-bf7ca6ec51f20b3164c5a46ba6b58199)
从查询结果可以看到,表中5个customer只有3个有email,其他customer的email为空值NULL的记录没有被COUNT()函数计算在内。
提示
两个例子中不同的数值说明了函数的两种调用方式在计算总数时对待NULL值的处理是不同的:指定字段时,字段值为空的行被COUNT()函数忽略;如果不指定字段而在COUNT()函数中使用星号“*”,则所有记录都不会COUNT()函数忽略。
前面讲述分组查询的时候,介绍了COUNT()函数与GROUP BY关键字一起使用,用来计算不同分组中的总记录数。
【例4.36】在orderitems表中,使用COUNT()函数统计不同订单号中订购的水果种类,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P134_55802.jpg?sign=1738900698-YWdUJfaVMjIsrVVpXAETYgCsSTFXlPOP-0-3de2f5502df5555388711d050ed05b71)
从查询结果可以看到,GROUP BY关键字先按照订单号进行分组,然后计算每个分组中的总记录数。
4.3.2 SUM()函数
SUM()是一个求总和的函数,返回指定字段值的总和。
【例4.37】在orderitems表中查询30005号订单一共购买的水果总量,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P134_55803.jpg?sign=1738900698-P6E0QA7TsWjLFQ8AjUHCFCvWOSX6b6Fy-0-eb22ce8417a670474dc1ce3e9786ea13)
从查询结果可以看到,SUM(quantity)函数返回订单中所有水果数量之和,WHERE子句指定查询的订单号为30005。
SUM()可以与GROUP BY一起计算每个分组的总和。
【例4.38】在orderitems表中,使用SUM()函数统计不同订单号中订购的水果总量,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P134_55804.jpg?sign=1738900698-dkWsI82mq71e2NXbYiSjhk9HAlbF3h1i-0-b75acbd3791ac31499a83ec0567c828a)
从查询结果可以看到,GROUP BY按照订单号o_num进行分组,SUM()函数计算每个分组中订购的水果总量。
提示
SUM()函数在计算时,忽略字段值为NULL的行。
4.3.3 AVG()函数
AVG()函数通过计算返回的行数和每一行中指定字段的数据之和,求得指定字段中数据的平均值。
【例4.39】在fruits表中,查询s_id=103的供应商的水果价格的平均值,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P135_55806.jpg?sign=1738900698-Re4ZjlNz8SWdjafhPaDn6jEfmEiMLJlu-0-945d89b0ce277c5acc8c444443dccab5)
在该例中,查询语句增加了一个WHERE子句,并且添加了查询筛选条件,只查询s_id =103的记录中的f_price。因此,通过AVG()函数计算的结果只是指定的供应商水果的价格平均值,而不是市场上所有水果的价格的平均值。
AVG()可以与GROUP BY一起计算每个分组的平均值。
【例4.40】在fruits表中,查询每一个供应商的水果价格的平均值,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P135_55807.jpg?sign=1738900698-xJnisqE058FYkXNAvcW3rjPhtZoyhgoK-0-3d84bb64677e2f00da573364c3244a2f)
GROUP BY关键字根据s_id字段对记录进行分组,然后计算出每个分组中水果价格的平均值,这种分组求平均值的方法非常有用,例如求不同班级学生成绩的平均值、求不同部门员工的平均工资、求各地的年平均气温等。
提示
调用AVG()函数时,注意其参数应为要计算的字段的名称,如果要得到多个字段的多个平均值,就需要在每一个字段上调用AVG()函数。
4.3.4 MAX()函数
MAX()返回指定字段中的最大值。
【例4.41】在fruits表中查找市场上价格最高的水果价格,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P136_55809.jpg?sign=1738900698-FmEiXg8cLHj5xoNynxmoXiRweBcS2tRJ-0-acd2bbbaa7355c1d5736f287add82173)
从结果可以看到,MAX()函数查询出了f_price字段的最大值为15.70。
MAX()也可以和GROUP BY关键字一起使用,求每个分组中的最大值。
【例4.42】在fruits表中查找不同供应商提供的最高水果价格,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P136_55810.jpg?sign=1738900698-FSCux3evSkPU4JYhmx707lUoEeEZLmvu-0-3038a3d93086a95ce55ccc9c418b3e9b)
从结果可以看到,GROUP BY关键字根据s_id字段对记录进行分组,然后找出每个分组中的最大值。
MAX()函数不仅适用于查找数值类型,也可以应用于字符类型。
【例4.43】在fruits表中查找f_name的最大值,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P137_55811.jpg?sign=1738900698-suqOArxbt6ZFdy1ijvQo57KhLAfCe0A2-0-967361cc053e28990fd8a1a0ae9287e4)
从结果可以看到,MAX()函数可以对字母进行大小判断,并返回最大的字符或者字符串值。
提示
MAX()函数除了用来找出最大的字段值或日期值之外,还可以返回任意字段中的最大值,包括返回字符类型的最大值。在对字符类型数据进行比较时,按照字符的ASCII码值大小进行比较,例如从a到z,a的ASCII码最小,z的最大。在比较时,先比较第一个字符,如果相等,就继续比较下一个字符,一直到两个字符不相等或者字符串结束为止。例如,'b'与't'比较时,'t'为最大值;'bcd'与'bca'比较时,'bcd'为最大值。
4.3.5 MIN()函数
MIN()返回查询字段中的最小值。
【例4.44】在fruits表中查找市场上最低的水果价格,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P137_55812.jpg?sign=1738900698-FPHqDqy44y0Chld0mSqYQylRnZ8ykTV7-0-0f86bd75766c98b696938a4330325771)
从结果可以看到,MIN ()函数查询出了f_price字段的最小值为2.20。
MIN()也可以和GROUP BY关键字一起使用,求出每个分组中的最小值。
【例4.45】在fruits表中查找不同供应商提供的最低水果价格,SQL语句如下:
![](https://epubservercos.yuewen.com/A12F53/15825992805223706/epubprivate/OEBPS/Images/Figure-P137_55813.jpg?sign=1738900698-tbPpaY80o81m8IwQrZ9AqwAVdVkGDXcB-0-dde6d9395a70d6be2c5027c72b4501f9)
从结果可以看到,GROUP BY关键字根据s_id字段对记录进行分组,然后计算出每个分组中的最小值。
MIN()函数与MAX()函数类似,不仅适用于数值类型,也可应用于字符类型。