Mysql:将日期从'dd/mm/yyyy'转换为'yyyymmdd'

Str*_*rae 6 mysql date

我正在研究一个在varchar(10)mysql字段中存储日期的数据库(太可悲了).

我无法改变数据库结构(即构建一个小插件),但我必须查询数据库,查找此数据字段在接下来的10天之间的行.

例:

| fid | fdate      |
|  1  | 10/09/2010 |
|  2  | 17/09/2010 |
|  3  | 19/09/2010 |
Run Code Online (Sandbox Code Playgroud)

我必须得到fid 1和2的行,因为日期是<=现在+ 10天.

通常我做这种查询:

SELECT fid FROM table WHERE fdate <= DATE_ADD(NOW(), INTERVAL 10 DAY);
Run Code Online (Sandbox Code Playgroud)

或者,如果日期的格式为"yyyymmdd":

SELECT fid FROM table WHERE fdate <= DATE_FORMAT(NOW(), '%Y%m%d');
Run Code Online (Sandbox Code Playgroud)

但它们对格式没用dd/mm/yyyy.

我已经想通了

SELECT fid, CONCAT(SUBSTRING(fdate, 7, 4), SUBSTRING(fdate, 4, 2), SUBSTRING(fdate, 1, 2)) AS mydate FROM table HAVING mydate <= DATE_ADD(NOW(), INTERVAL 10 DAY);
Run Code Online (Sandbox Code Playgroud)

但我想用concat和substring重建日期格式有点过分,并且该having子句不会帮助查询速度.

任何的想法?

编辑

在Adriano的评论之后,正确的解决方案是

SELECT fid FROM test WHERE STR_TO_DATE(fdate, '%d/%m/%Y') <= DATE_ADD(NOW(), INTERVAL 10 DAY);
Run Code Online (Sandbox Code Playgroud)

所以我可以避免concat和having子句.

Adr*_*zza 7

使用str_to_date()从格式创建日期怎么样?

在阅读评论后编辑,我创建了一个像你一样的表格:

mysql> SELECT fid, fdate FROM test;
+------+------------+
| fid  | fdate      |
+------+------------+
|    1 | 10/9/2010  | 
|    2 | 17/9/2010  | 
|    3 | 19/09/2010 | 
+------+------------+
Run Code Online (Sandbox Code Playgroud)

然后呢

mysql> SELECT fid FROM test WHERE STR_TO_DATE(fdate, '%d/%m/%Y') <= DATE_ADD(NOW(), INTERVAL 10 DAY);
+------+
| fid  |
+------+
|    1 | 
|    2 | 
+------+
Run Code Online (Sandbox Code Playgroud)

似乎工作.你到底得到了什么?