MySQL数据库--分组与统计

目录

1.统计函数

1.1COUNT()函数

1.2SUM()函数

1.3AVG()函数

1.4MAX()函数

1.5MIN()函数

2.分组查询

2.1单独使用GROUP BY分组查询

2.2使用GROUP BY分组和统计函数一起查询

2.3HAVING限制分组查询结果


欢迎

1.统计函数

有时我们要的不是数据表中的原始数据,而是需要进行一点简单加工后的统计数据。

函数功能描述
COUNT()统计数据表中记录的行数
SUM()计算某字段值的总和
AVG()计算某字段的平均值
MAX()计算某字段值的最大值
MIN()计算某字段的最小值

1.1COUNT()函数

基本语法:

SEKECT COUNT(*)FROM 数据表名;

例:

查询数据表product中共有多少个商品记录

SELECT COUNT(*)FROM product;

1.2SUM()函数

基本语法:

SELECT SUM(字段名)FROM 数据表名;

例;

查询数据表profuct中的商品价格字段的总和

SELECT SUM(prod_price)FROM product;

1.3AVG()函数

语法:

SELECT AVG(字段名)FRM数据表名;

例:

查询数据表product中的商品价格字段的平均值

SELECT AVG(prod_price)FROM product;

1.4MAX()函数

语法:

SELECT MAX(字段名)FROM数据表名;

例:

查询数据表product中的商品价格字段的最大值

SELECT MAX(prod_price)FROM product;

1.5MIN()函数

语法:

SELECT MIN(字段名)FROM 数据表名;

例:

查询数据表product表中的商品价格字段的最小值

SELECT SUM(prod_price)FROM product;

2.分组查询

 在对数据表中的数据进行处理时,有时需要按照某个字段进行类别划分,然后针对不同分组进行统计。

MySQL提供了关键字GROUP BY来处理这一需求,GROUP BY可以根据某个或多个字段的值进行进行分组,字段值相同的划分为一组,基本语法如下:

SELECT 字段1,字段2,...
FROM 数据表名
GROUP BY 字段1,字段2,...
[HAVING 条件表达式];

2.1单独使用GROUP BY分组查询

例:

将数据表product中的记录按照供应商字段vend_id大的值进行分组

SELECT * FROM product GROUP BY vend_id;

2.2使用GROUP BY分组和统计函数一起查询

例;

将数据表product中的记录按照供应商字段vend_id的值进行分组,并显示prod_price字段的总和、均值、最大值、最小值

先按vend_id字段进行分组,再在分组基础上运行6个不同的统计函数

SELECT 
vend_id,COUNT(*),SUN(prod_price),AVG(prod_price),MAX(prod_price),MIN(prod_price)
FROM product
GROUP BY vend_id;

2.3HAVING限制分组查询结果

例;

将数据表product中的记录按照供应商字段vend_id的值进行分组,并显示prod_price字段的总和、均值、最大值、最小值,值显示prod_price字段均值在15以下的分组

SELECT 
vend_id,COUNT(*),SUN(prod_price),AVG(prod_price),MAX(prod_price),MIN(prod_price)
FROM product
GROUP BY vend_id
HAVING AVG(prof_price)<15;

感谢观看,再见

  • 18
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 28
    评论
### 回答1: MySQL数据库可以使用`GROUP BY`语句来进行分组查询。例如,如果你想按照顾客的国家分组查询订单总额,你可以使用以下查询: ``` SELECT customer_country, SUM(order_total) FROM orders GROUP BY customer_country; ``` 这会返回每个国家的订单总额,并将这些订单按照国家分组。 你还可以使用`HAVING`子句来筛选分组,例如,如果你想查询订单总额大于1000美元的国家,你可以使用以下查询: ``` SELECT customer_country, SUM(order_total) FROM orders GROUP BY customer_country HAVING SUM(order_total) > 1000; ``` 这会返回订单总额大于1000美元的国家及其订单总额。 希望这能帮助你! ### 回答2: MySQL数据库分组查询是指通过使用GROUP BY关键字将数据按照指定的列进行分组,并对每个分组进行聚合计算。下面是分组查询的基本语法: SELECT 列1, 列2, ... FROM 表名 GROUP BY 列1, 列2, ... HAVING 条件; 其中,列1, 列2, ...表示要查询的列名;表名表示要查询的数据表;列1, 列2, ...表示要进行分组的列;条件是对分组结果进行筛选的条件。 例如,我们有一个学生成绩表score,包含学生姓名(name)、科目(subject)和成绩(score)三个列。现在需要按照科目进行分组,计算每个科目的平均分,并筛选出平均分大于80的科目。 查询语句如下: SELECT subject, AVG(score) AS average_score FROM score GROUP BY subject HAVING average_score > 80; 在这个例子中,我们选择了科目列和使用AVG函数计算平均分,使用GROUP BY关键字按照科目进行分组,然后使用HAVING条件筛选出平均分大于80的科目。最终的查询结果为每个科目的平均分。 需要注意的是,在使用GROUP BY进行分组查询时,查询的列必须要么出现在GROUP BY子句中,要么出现在聚合函数中。否则,MySQL会报错。同时,HAVING条件用于筛选分组结果,只有满足该条件的分组才会被返回。 通过分组查询,我们可以方便地对数据进行分类统计和汇总分析,提供更有价值的信息。 ### 回答3: MySQL数据库分组查询可以使用GROUP BY子句来实现。GROUP BY子句将查询的结果按照指定的列进行分组,并根据每个组进行数据聚合计算。 基本语法如下: SELECT 列名1, 列名2, ... FROM 表名 GROUP BY 列名1, 列名2, ... 例如,假设有一个名为"students"的表,包含学生的姓名和年龄两列。我们希望统计每个年龄段的学生人数,可以使用以下查询语句: SELECT 年龄, COUNT(*) AS 人数 FROM students GROUP BY 年龄 以上查询会按照年龄分组,并统计每个年龄组的学生人数。使用COUNT(*)函数可以计算每个分组中的记录数。 若希望在分组的基础上,进一步筛选满足条件的结果,可使用HAVING子句。HAVING子句的使用方式与WHERE子句类似,区别在于WHERE子句用于过滤记录,而HAVING子句用于过滤分组。 例如,查询年龄大于等于18岁,并且人数超过10人的年龄段: SELECT 年龄, COUNT(*) AS 人数 FROM students GROUP BY 年龄 HAVING 年龄 >= 18 AND COUNT(*) > 10 以上查询会先按年龄分组,然后筛选出年龄大于等于18岁且人数超过10人的结果。 使用GROUP BY子句可以对查询结果进行分组计算,从而方便进行统计和分析。在实际应用中,我们可以根据具体需求灵活运用分组查询来满足不同的数据分析需求。
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pzn)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值