MySQL从表的datetime列中选择不同的日期?

您需要使用DISTINCT关键字从表的datetime列中选择不同的日期。

例如,让我们创建一个表

mysql> create table PostMesssageDemo
   - > (
   - > UserId int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   - > UserMessage varchar(100),
   - > UserPost datetime
   - > );

现在,您可以使用insert命令在表中插入一些记录。

查询如下

mysql> insert into PostMesssageDemo(UserMessage,UserPost) values('Software Developer',now());
mysql> insert into PostMesssageDemo(UserMessage,UserPost) values('Software Developer',date_add(now(),interval 3 month));
mysql> insert into PostMesssageDemo(UserMessage,UserPost) values('Software Developer',now());
mysql> insert into PostMesssageDemo(UserMessage,UserPost) values('Software Developer','2019-03-31 17:30:34');

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

查询如下

mysql> select *from PostMesssageDemo;

以下是输出

+--------+--------------------+---------------------+
| UserId | UserMessage        | UserPost            |
+--------+--------------------+---------------------+
|      1 | Software Developer | 2019-02-15 18:07:27 |
|      2 | Software Developer | 2019-05-15 18:09:18 |
|      3 | Software Developer | 2019-02-15 18:09:31 |
|      4 | Software Developer | 2019-03-31 17:30:34 |
+--------+--------------------+---------------------+
4 rows in set (0.00 sec)

以下是查询以获取不同的日期

mysql> select distinct year(UserPost),month(UserPost) from PostMesssageDemo;

这是输出

+----------------+-----------------+
| year(UserPost) | month(UserPost) |
+----------------+-----------------+
|           2019 |               2 |
|           2019 |               5 |
|           2019 |               3 |
+----------------+-----------------+
3 rows in set (0.00 sec)