MySQL / SQL:仅在Datetime列上按日期分组
有一个带有列的表,如: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来完成此操作,但我不知道如何:(。
回答:
将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;
尽管我认为这不会对性能产生任何影响,但它会更清晰一些。
以上是 MySQL / SQL:仅在Datetime列上按日期分组 的全部内容, 来源链接: utcz.com/qa/410853.html