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

时间:2010-09-07 14:00:37

标签: mysql date

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

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

示例:

| fid | fdate      |
|  1  | 10/09/2010 |
|  2  | 17/09/2010 |
|  3  | 19/09/2010 |

我必须得到带有fid 1和2的行,因为日期是< = now + 10天。

通常我会提出这样的问题:

SELECT fid FROM table WHERE fdate <= DATE_ADD(NOW(), INTERVAL 10 DAY);

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

SELECT fid FROM table WHERE fdate <= DATE_FORMAT(NOW(), '%Y%m%d');

但它们对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);

但我认为使用concat和substring重建日期格式有点过分,而having子句不会帮助查询速度。

有什么想法吗?

修改

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

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

所以我可以避免使用concat和having子句。

1 个答案:

答案 0 :(得分:7)

如何使用str_to_date()从格式创建日期?

编辑阅读完评论后,我创建了一个类似你的表格:

mysql> SELECT fid, fdate FROM test;
+------+------------+
| fid  | fdate      |
+------+------------+
|    1 | 10/9/2010  | 
|    2 | 17/9/2010  | 
|    3 | 19/09/2010 | 
+------+------------+

然后做了

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

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