MySQL语句 | 使用DATE_FORMAT()对查询结果按日、周、月分组统计

文章目录

  • 语法
    • 举个通用的例子
  • 按照年月日进行分组统计
    • 举个通用的例子
    • 举个实际的例子

在MySQL中,
DATE_FORMAT() 函数可用于将日期按照指定的格式进行格式化,也可用于对数据记录按照不同的时间维度进行分组

语法

DATE_FORMAT(date, format)

其中,date 是要格式化的日期,而 format 则是格式化的规则。

举个通用的例子

假设有一个名为 orders 的表,其中包含一个日期列 order_date

SELECT order_date, DATE_FORMAT(order_date, '%Y-%m-%d') AS formatted_date
FROM orders;

在上面的查询中,DATE_FORMAT() 函数将 order_date 列按照 '%Y-%m-%d' 的格式进行格式化,以显示年-月-日的形式。

以下是一些常见的日期格式化选项,可根据实际需求选择不同的格式:

  • %Y: 四位年份
  • %m: 两位月份(01到12)
  • %d: 两位日期(01到31)
  • %H: 小时(00到23)
  • %i: 分钟(00到59)
  • %s: 秒(00到59)

按照年月日进行分组统计

在MySQL中可以使用 DATE_FORMAT() 函数对数据记录按日、周、月进行分组统计

举个通用的例子

  1. 按日分组统计:
SELECT DATE_FORMAT(order_date, '%Y-%m-%d') AS day,
       COUNT(*) AS order_count
FROM orders
GROUP BY day;
  1. 按周分组统计:
SELECT DATE_FORMAT(order_date, '%Y-%u') AS week,
       COUNT(*) AS order_count
FROM orders
GROUP BY week;
  1. 按月分组统计:
SELECT DATE_FORMAT(order_date, '%Y-%m') AS month,
       COUNT(*) AS order_count
FROM orders
GROUP BY month;

这三个查询分别按照日、周、月进行分组统计订单数量,在实际应用中可根据实际情况调整表名和字段名或者添加其他的聚合函数。

举个实际的例子

假设有一个名为 sales 的表,其中包含字段:sale_date(销售日期)和 amount(销售金额)

  1. 按日分组统计:
SELECT DATE_FORMAT(sale_date, '%Y-%m-%d') AS day,
       SUM(amount) AS total_amount
FROM sales
GROUP BY day;

这个查询将销售日期按照年-月-日格式化,并统计每天的销售总金额

  1. 按周分组统计:
SELECT DATE_FORMAT(sale_date, '%Y-%u') AS week,
       SUM(amount) AS total_amount
FROM sales
GROUP BY week;

这个查询将销售日期按照年-周格式化,并统计每周的销售总金额。

  1. 按月分组统计:
SELECT DATE_FORMAT(sale_date, '%Y-%m') AS month,
       SUM(amount) AS total_amount
FROM sales
GROUP BY month;

这个查询将销售日期按照年-月格式化,并统计每月的销售总金额。