在作为VARCHAR值插入表中的日期上执行MySQL SELECT

让我们首先创建一个表-

mysql> create table DemoTable
(
   DueDate varchar(100)
);

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

mysql> insert into DemoTable values('21/10/2018');
mysql> insert into DemoTable values('18/08/2019');
mysql> insert into DemoTable values('01/12/2012');
mysql> insert into DemoTable values('31/01/2016');

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

mysql> select *from DemoTable;

这将产生以下输出-

+------------+
| DueDate    |
+------------+
| 21/10/2018 |
| 18/08/2019 |
| 01/12/2012 |
| 31/01/2016 |
+------------+
4 rows in set (0.00 sec)

以下是查询以VARCHAR形式对上表中包含的日期执行SELECT。在这里,我们获取日期为2010-01-31之后的所有日期记录-

mysql> select *from DemoTable where str_to_date(DueDate,'%d/%m/%Y') > '2010-01-31';

这将产生以下输出-

+------------+
| DueDate    |
+------------+
| 21/10/2018 |
| 18/08/2019 |
| 01/12/2012 |
| 31/01/2016 |
+------------+
4 rows in set (0.00 sec)