小编典典

MySQL / SQL:仅在Datetime列上按日期分组

mysql

有一个带有列的表,如:mydate DATETIME

我有一个查询,例如:

SELECT SUM(foo), mydate FROM a_table GROUP BY a_table.mydate;

这将按完整的分组datetime,包括小时和分钟。我希望按日期分组,YYYY/MM/DD而不按日期分组YYYY/MM/DD/HH/mm

有人知道怎么做吗?我仍然可以在我的代码中动态地执行此操作(因为我是atm),但是我正在清理垃圾代码,并且可以通过SQL来完成此操作,但我不知道如何:(。


阅读 502

收藏
2020-05-17

共1个答案

小编典典

将datetime强制转换为日期,然后使用以下语法将GROUP BY强制转换为:

SELECT SUM(foo), DATE(mydate) FROM a_table GROUP BY DATE(a_table.mydate);

或者,您可以按@ orlandu63建议使用GROUP BY别名:

SELECT SUM(foo), DATE(mydate) DateOnly FROM a_table GROUP BY DateOnly;

尽管我认为这不会对性能产生任何影响,但它会更清晰一些。

2020-05-17