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)