如何在 MySQL 中根据日期分组,而不管时间是多少?


在表中,当同一天有多个不同的时间值时,可以使用 GROUP BY DATE 轻松地将它们分组。

让我们首先创建一个表 -

mysql> create table DemoTable692 (DueDatetime datetime);
Query OK, 0 rows affected (0.97 sec)

使用 insert 命令在表中插入一些记录

mysql> insert into DemoTable692 values('2019-07-21 10:20:00');
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable692 values('2019-06-11 11:00:10');
Query OK, 1 row affected (0.24 sec)
mysql> insert into DemoTable692 values('2019-07-21 11:00:10');
Query OK, 1 row affected (1.97 sec)
mysql> insert into DemoTable692 values('2019-07-21 12:10:10');
Query OK, 1 row affected (0.18 sec)

使用 select 语句显示表中的所有记录

mysql> select *from DemoTable692;

将生成以下输出 -

+---------------------+
| DueDatetime         |
+---------------------+
| 2019-07-21 10:20:00 |
| 2019-06-11 11:00:10 |
| 2019-07-21 11:00:10 |
| 2019-07-21 12:10:10 |
+---------------------+
4 rows in set (0.00 sec)

下面是查询,实现无论时间如何都按日期分组 -

mysql> select *from DemoTable692 GROUP BY DATE(DueDatetime);

将生成以下输出 -

+---------------------+
| DueDatetime         |
+---------------------+
| 2019-07-21 10:20:00 |
| 2019-06-11 11:00:10 |
+---------------------+
2 rows in set (0.00 sec)

更新于: 2019-08-21

374 次浏览

开启你的 职业生涯

完成课程获得认证

开始学习
广告
© . All rights reserved.