在 MySQL 中比较日期字符串


要比较日期字符串,请使用 MySQL 中的函数 STR_TO_DATE()。

我们先创建一个表 -

mysql> create table DemoTable712 (
   Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   ArrivalDate varchar(100)
);
Query OK, 0 rows affected (0.65 sec)

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

mysql> insert into DemoTable712(ArrivalDate) values('10.01.2019');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable712(ArrivalDate) values('11.12.2018');
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable712(ArrivalDate) values('01.11.2017');
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable712(ArrivalDate) values('20.06.2016');
Query OK, 1 row affected (0.23 sec)

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

mysql> select *from DemoTable712;

这将生成以下输出 -

+----+-------------+
| Id | ArrivalDate |
+----+-------------+
| 1  | 10.01.2019  |
| 2  | 11.12.2018  |
| 3  | 01.11.2017  |
| 4  | 20.06.2016  |
+----+-------------+
4 rows in set (0.00 sec)

以下是比较日期字符串的查询 -

mysql> select *from DemoTable712 where str_to_date(ArrivalDate,'%d.%m.%Y')='2017-11-01';

这将生成以下输出 -

+----+-------------+
| Id | ArrivalDate |
+----+-------------+
| 3  | 01.11.2017  |
+----+-------------+
1 row in set (0.00 sec)

更新于: 22/8/2019

1000+ 浏览

开启你的 事业

通过完成课程获得认证

开始
广告