mysql之聚合函数

打印 上一主题 下一主题

主题 700|帖子 700|积分 2100



聚合函数通常在 SQL 查询中与 GROUP BY 语句一起使用,它们对一组值执行计算并返回单个值。以下是一个示例 SQL 查询,它联合使用了多个聚合函数来演示它们的用法:
假设我们有一个名为 sales 的表,它包含了 amount 和 date 两个字段,分别表示销售额和销售日期:
  1. CREATE TABLE sales ( id INT AUTO_INCREMENT PRIMARY KEY,amount DECIMAL(10, 2), sale_date DATE);
复制代码
如今,我们使用一个查询来演示如何使用聚合函数来获取总销售额、平均销售额、最高销售额、最低销售额和销售记录数目:
  1. SELECT COUNT(*) AS total_sales_count, <em>-- 总销售记录数</em>
  2. SUM(amount) AS total_sales, <em>-- 总销售额</em>
  3. AVG(amount) AS average_sale, <em>-- 平均销售额</em>
  4. MAX(amount) AS highest_sale, <em>-- 最高销售额</em>
  5. MIN(amount) AS lowest_sale <em>-- 最低销售额
  6. </em>FROM sales;
复制代码
在这个查询中,每个聚合函数都作用于 sales 表的 amount 字段,除了 COUNT(*),它是用来统计总的销售记录数。
如果我们想要根据某个时间段(比如每个月)来分组统计这些数据,我们可以添加 GROUP BY 语句:
  1. SELECT YEAR(sale_date) AS sale_year,
  2. MONTH(sale_date) AS sale_month,
  3. COUNT(*) AS total_sales_count,
  4. SUM(amount) AS total_sales,
  5. AVG(amount) AS average_sale,
  6. MAX(amount) AS highest_sale,
  7. MIN(amount) AS lowest_sale
  8. FROM sales
  9. GROUP BY YEAR(sale_date), MONTH(sale_date);
复制代码
这个查询将 sales 表中的记录按年份和月份进行分组,并计算每个组的总销售记录数、总销售额、平均销售额、最高销售额和最低销售额。
聚合函数的详细介绍:


  • COUNT(*): 计算表中的行数,可以包括 NULL 值。
  • SUM(column): 返回指定列的数值总和。
  • AVG(column): 返回指定列的平均值。
  • MAX(column): 返回指定列的最大值。
  • MIN(column): 返回指定列的最小值。
请留意,聚合函数通常忽略 NULL 值,除非另有阐明(例如,COUNT(*) 包括所有行,即使其中的列值为 NULL)。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

北冰洋以北

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表