我正在研究一个在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子句.
使用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)
似乎工作.你到底得到了什么?