分组X天

Liz*_*ard 5 mysql grouping group-by

我有一组或多个记录,我想计算并将它们分组到一定的范围,例如我想要计算由X天组创建的记录

e.g. SELECT COUNT(*) FROM `table` GROUP BY /*`created` 3 days/*
Run Code Online (Sandbox Code Playgroud)

Ron*_*nis 6

这是一个日期示例.

create table t1(created date not null);

insert 
  into t1(created) values (date '2011-01-09')
                         ,(date '2011-01-10')
                         ,(date '2011-01-11')
                         ,(date '2011-01-12')
                         ,(date '2011-01-13')
                         ,(date '2011-01-14')
                         ,(date '2011-01-15')
                         ,(date '2011-01-16')
                         ,(date '2011-01-17')
                         ,(date '2011-01-18')
                         ,(date '2011-01-19')
                         ,(date '2011-01-20');

select floor(datediff(now(), created) / 3) * 3 as days_ago
      ,min(created)
      ,max(created)
      ,count(*)
  from t1
 group 
    by floor(datediff(now(), created) / 3);

+----------+--------------+--------------+----------+
| days_ago | min(created) | max(created) | count(*) |
+----------+--------------+--------------+----------+
|        0 | 2011-01-18   | 2011-01-20   |        3 |
|        3 | 2011-01-15   | 2011-01-17   |        3 |
|        6 | 2011-01-12   | 2011-01-14   |        3 |
|        9 | 2011-01-09   | 2011-01-11   |        3 |
+----------+--------------+--------------+----------+
4 rows in set (0.00 sec)
Run Code Online (Sandbox Code Playgroud)


Sam*_*fel 4

你可以做类似的事情
SELECT COUNT(*) FROM table GROUP BY FLOOR(created / 3)

... 我认为。

尽管 ifcreated是一个日期字段,但您需要做更多的调整才能将其转换为数字值才能正常工作。