是否可以做一个简单的查询来计算我在一个确定的时间段内有多少记录,比如一年,一个月,或者一天,有一个TIMESTAMP字段,比如:

SELECT COUNT(id)
FROM stats
WHERE record_date.YEAR = 2009
GROUP BY record_date.YEAR

甚至:

SELECT COUNT(id)
FROM stats
GROUP BY record_date.YEAR, record_date.MONTH

每月进行统计。

谢谢!


当前回答

我更喜欢这样优化一年期组的选择:

SELECT COUNT(*)
  FROM stats
 WHERE record_date >= :year 
   AND record_date <  :year + INTERVAL 1 YEAR;

这样你就可以把年份绑定在一起。'2009',带有命名参数,无需担心添加'-01-01'或单独传入'2010'。

另外,假设我们只是计算行数,id从不为NULL,我更喜欢COUNT(*)而不是COUNT(id)。

其他回答

这里还有一种方法。这使用[MySQL的LAST_DAY()函数][1]将每个时间戳映射到它的月份。如果在record_date上有索引,它还能够通过有效的范围扫描按年进行过滤。

  SELECT LAST_DAY(record_date) month_ending, COUNT(*) record_count
    FROM stats
   WHERE record_date >= '2000-01-01'
     AND record_date <  '2000-01-01' + INTERVAL 1 YEAR
   GROUP BY LAST_DAY(record_date) 

如果希望按天计算结果,请使用DATE(record_date)。

如果您希望按日历季度获得结果,请使用YEAR(record_date), quarter (record_date)。

这是一个记录。https://www.plumislandmedia.net/mysql/sql-reporting-time-intervals/ [1]: https://dev.mysql.com/doc/refman/8.0/en/date-and-time-functions.html # function_last-day

GROUP BY YEAR(record_date), MONTH(record_date)

查看MySQL中的日期和时间函数。

如果你想在MySQL中按日期分组,那么使用下面的代码:

 SELECT COUNT(id)
 FROM stats
 GROUP BY DAYOFMONTH(record_date)

希望这为那些要找到这个帖子的人节省了一些时间。

试一试

按年(record_date),月(record_date)分组

.... group by to_char(date, 'YYYY')——> 1989

.... group by to_char(date,'MM')——>05

.... 3 .用to_char(date,'DD')——>

.... group by to_char(date,'MON')——>

.... 9 . group by to_char(date,'YY')——>