Answers:
GROUP BY YEAR(record_date), MONTH(record_date)
在MySQL中检查日期和时间函数。
SELECT count(*), record_date FROM anytable WHERE anytable.anycolumn = 'anycondition' GROUP BY YEAR(record_date), month(record_date);
注意:record_date是日期类型TIMESTAMP
GROUP BY DATE_FORMAT(record_date, '%Y%m')
注意(首先要注意潜在的拒绝者)。目前,这可能不如其他建议有效。尽管如此,我仍然将其作为替代方案,也可以用来观察其他解决方案的速度。(因为在看到差异之前,您不能从慢到快真正分辨出来。)而且,随着时间的流逝,可以对MySQL的引擎进行优化方面的更改,以便在某些情况下(例如,并非如此)做出此解决方案。远点),使其在效率上可以与大多数其他产品媲美。
试试这个
SELECT COUNT(id)
FROM stats
GROUP BY EXTRACT(YEAR_MONTH FROM record_date)
EXTRACT(unit FROM date)函数更好,因为使用的分组较少,并且该函数返回数字值。
分组时的比较条件将比DATE_FORMAT函数(返回字符串值)快。尝试使用返回SQL比较条件(WHERE,HAVING,ORDER BY,GROUP BY)的非字符串值的function | field。
如果您的搜索时间超过几年,并且仍然希望每月进行分组,建议您:
版本1:
SELECT SQL_NO_CACHE YEAR(record_date), MONTH(record_date), COUNT(*)
FROM stats
GROUP BY DATE_FORMAT(record_date, '%Y%m')
版本#2(效率更高):
SELECT SQL_NO_CACHE YEAR(record_date), MONTH(record_date), COUNT(*)
FROM stats
GROUP BY YEAR(record_date)*100 + MONTH(record_date)
我在一张有1,357,918行的大表上比较了这些版本(Innodb),第二版似乎有更好的结果。
版本1 (平均执行10次):1.404秒
版本2 (平均执行10次):0.780秒
(SQL_NO_CACHE
添加了此键以防止MySQL缓存到查询。)
GROUP BY YEAR(record_date)*100 + MONTH(record_date)
,但为什么不同时进行测试GROUP BY YEAR(record_date), MONTH(record_date)
呢?
*100
Versión#2上的内容是什么?提前致谢。
*100
至YEAR(record_date)*100 + MONTH(record_date) == DATE_FORMAT(record_date, '%Y%m')
如果要在MySQL中按日期分组,请使用以下代码:
SELECT COUNT(id)
FROM stats
GROUP BY DAYOFMONTH(record_date)
希望这可以为将要查找此线程的人节省一些时间。
MONTH(record_date)
以占多个月的时间。
如果要过滤特定年份(例如2000)的记录,则可以WHERE
像下面这样优化子句:
SELECT MONTH(date_column), COUNT(*)
FROM date_table
WHERE date_column >= '2000-01-01' AND date_column < '2001-01-01'
GROUP BY MONTH(date_column)
-- average 0.016 sec.
代替:
WHERE YEAR(date_column) = 2000
-- average 0.132 sec.
针对包含30万行和日期索引列的表生成结果。
至于GROUP BY
条款,我对照上述表格测试了三种变体。结果如下:
SELECT YEAR(date_column), MONTH(date_column), COUNT(*)
FROM date_table
GROUP BY YEAR(date_column), MONTH(date_column)
-- codelogic
-- average 0.250 sec.
SELECT YEAR(date_column), MONTH(date_column), COUNT(*)
FROM date_table
GROUP BY DATE_FORMAT(date_column, '%Y%m')
-- Andriy M
-- average 0.468 sec.
SELECT YEAR(date_column), MONTH(date_column), COUNT(*)
FROM date_table
GROUP BY EXTRACT(YEAR_MONTH FROM date_column)
-- fu-chi
-- average 0.203 sec.
最后一个是获胜者。
您只需在GROUP BY中执行Mysql DATE_FORMAT()函数即可。在某些情况下(例如记录跨度数年而不同月份出现同一月数),您可能需要添加额外的列以提高清晰度。请从头开始阅读。希望对您有帮助。这是示例查询供您理解
SELECT
COUNT(id),
DATE_FORMAT(record_date, '%Y-%m-%d') AS DAY,
DATE_FORMAT(record_date, '%Y-%m') AS MONTH,
DATE_FORMAT(record_date, '%Y') AS YEAR
FROM
stats
WHERE
YEAR = 2009
GROUP BY
DATE_FORMAT(record_date, '%Y-%m-%d ');
.... group by to_char(date, 'YYYY')
-> 1989年
.... group by to_char(date,'MM')
-> 05
.... group by to_char(date,'DD')
-> 23
.... group by to_char(date,'MON')
---> MAY
.... group by to_char(date,'YY')
-> 89
GROUP BY record_date.MONTH
在您的第一个代码段中?