mysql之聚合函数

聚合函数通常在 SQL 查询中与 GROUP BY 语句一起使用,它们对一组值执行计算并返回单个值。以下是一个示例 SQL 查询,它结合使用了多个聚合函数来演示它们的用法:

假设我们有一个名为 sales 的表,它包含了 amountdate 两个字段,分别表示销售额和销售日期:

CREATE TABLE sales ( id INT AUTO_INCREMENT PRIMARY KEY,amount DECIMAL(10, 2), sale_date DATE);

现在,我们使用一个查询来演示如何使用聚合函数来获取总销售额、平均销售额、最高销售额、最低销售额和销售记录数量:

SELECT COUNT(*) AS total_sales_count, -- 总销售记录数 
SUM(amount) AS total_sales, -- 总销售额 
AVG(amount) AS average_sale, -- 平均销售额 
MAX(amount) AS highest_sale, -- 最高销售额 
MIN(amount) AS lowest_sale -- 最低销售额
FROM sales;

在这个查询中,每个聚合函数都作用于 sales 表的 amount 字段,除了 COUNT(*),它是用来统计总的销售记录数。

如果我们想要根据某个时间段(比如每个月)来分组统计这些数据,我们可以添加 GROUP BY 语句:

SELECT YEAR(sale_date) AS sale_year, 
MONTH(sale_date) AS sale_month, 
COUNT(*) AS total_sales_count, 
SUM(amount) AS total_sales, 
AVG(amount) AS average_sale, 
MAX(amount) AS highest_sale, 
MIN(amount) AS lowest_sale 
FROM sales 
GROUP BY YEAR(sale_date), MONTH(sale_date);

这个查询将 sales 表中的记录按年份和月份进行分组,并计算每个组的总销售记录数、总销售额、平均销售额、最高销售额和最低销售额。

聚合函数的详细介绍:

  • COUNT(*): 计算表中的行数,可以包括 NULL 值。

  • SUM(column): 返回指定列的数值总和。

  • AVG(column): 返回指定列的平均值。

  • MAX(column): 返回指定列的最大值。

  • MIN(column): 返回指定列的最小值。

请注意,聚合函数通常忽略 NULL 值,除非另有说明(例如,COUNT(*) 包括所有行,即使其中的列值为 NULL)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

兔老大RabbitMQ

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

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

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

打赏作者

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

抵扣说明:

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

余额充值