我正在处理一个在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子句。
答案 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 |
+------+
似乎工作。你到底得到了什么?