• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL 分组查询和聚合函数

mysql 搞代码 4年前 (2022-01-09) 33次浏览 已收录 0个评论

概述

相信我们经常会遇到这样的场景:想要了解双十一天猫购买化妆品的人员中平均消费额度是多少(这可能有利于对商品价格区间的定位);或者不同年龄段的化妆品消费占比是多少(这可能有助于对商品备货量的预估)。

这个时候就要用到分组查询,分组查询的目的是为了把数据分成多个逻辑组(购买化妆品的人员是一个组,不同年龄段购买化妆品的人员也是组),并对每个组进行聚合计算的过程:。

分组查询的语法格式如下:

 select cname, group_fun,... from tname [where condition]
 group by group_expression [having group_condition]; 

说明一下:

1、group_fun 代表聚合函数,是指对分组的数据进行聚合计算的函数。

2、group_expression 代表分组表达式,允许多个,多个之间使用逗号隔开。

3、group_condition 分组之后,再对分组后的数据进行条件过滤的过程。

4、分组语法中,select后面出现的字段 要么是group by后面的字段,要么是聚合函数的列,其他类型会报异常,我们下面的内容中会详细说明。 

说分组之前,先来看看聚合函数,聚合函数是分组查询语法格式中重要的一部分。我们经常需要汇总数据而不用把它们实际检索出来,所以MySQL提供了专门的函数。使用这些函数,可用于计算我们需要的数据,以便分析和生成报表。

聚合函数

聚合函数有以下几种。 

函数 说明
AVG() 返回指定字段的平均值
COUNT() 返回查询结果行数
MAX() 返回指定字段的最大值 
MIN() 返回指定字段的最小值
SUM() 返回指定字段的求和值

AVG()函数

AVG()通过对表中行数计数并计算特定列值之和,求得该列的平均值。 AVG()可用来返回所有列的平均值,也可以用来返回特定列或行的平均值。

下面示例返回用户表中用户的平均年龄:

mysql> select * from user2;
+----+--------+------+----------+-----+
| id | name  | age | address | sex |
+----+--------+------+----------+-----+
| 1 | brand |  21 | fuzhou  |  1 |
| 2 | helen |  20 | quanzhou |  0 |
| 3 | sol  |  21 | xiamen  |  0 |
| 4 | weng  |  33 | guizhou |  1 |
| 5 | selina |  25 | NULL   |  0 |
| 6 | anny  |  23 | shanghai |  0 |
| 7 | annd  |  24 | shanghai |  1 |
| 8 | sunny | NULL | guizhou |  0 |
+----+--------+------+----------+-----+
8 rows in set

mysql> select avg(age) from user2;
+----------+
| avg(age) |
+----------+
| 23.8571 |
+----------+
1 row in set

注意点:

1、AVG()只能用来确定特定数值列的平均值 。
2、AVG()函数忽略列值为NULL的行,所以上图中age值累加之后是除以7,而不是除以8。  

COUNT()函数

COUNT()函数进行计数。 可以用COUNT()确定表中符合条件的行的数目。

count 有 count(*)、count(具体字段)、count(常量) 三种方式来体现 下面 演示了count(*) 和 count(cname)的用法。

mysql> select * from user2;
+----+--------+------+----------+-----+
| id | name  | age | address | sex |
+----+--------+------<em>本文来源gao.dai.ma.com搞@代*码(网$</em>+----------+-----+
| 1 | brand |  21 | fuzhou  |  1 |
| 2 | helen |  20 | quanzhou |  0 |
| 3 | sol  |  21 | xiamen  |  0 |
| 4 | weng  |  33 | guizhou |  1 |
| 5 | selina |  25 | NULL   |  0 |
| 6 | anny  |  23 | shanghai |  0 |
| 7 | annd  |  24 | shanghai |  1 |
| 8 | sunny | NULL | guizhou |  0 |
+----+--------+------+----------+-----+
8 rows in set

mysql> select count(*) from user2 where sex=0;
+----------+
| count(*) |
+----------+
|    5 |
+----------+
1 row in set

mysql> select count(age) from user2 where sex=0;
+------------+
| count(age) |
+------------+
|     4 |
+------------+
1 row in set

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL 分组查询和聚合函数

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址