使用mysql转换和过滤datetime

使用mysql转换和过滤datetime,date,datetime,mysqli,date-format,Date,Datetime,Mysqli,Date Format,我正在努力从现在开始获取所有日期(所有日期都是从今天或未来开始的) 很遗憾,我的日期格式为:'%d%m%Y%H:i'(08.06.2013 12:00) 我尝试了几件事,最后一件是: SELECT * FROM `events` WHERE DATE_FORMAT(SUBSTRING(enddate,1,9),'%Y%m%d') >= DATE_FORMAT(CURDATE(),'%Y%m%d') 我认为这将转化为:(日期=27.08.2013) 但它现在起作用了。。。我得到了太多的结果

我正在努力从现在开始获取所有日期(所有日期都是从今天或未来开始的)

很遗憾,我的日期格式为:'%d%m%Y%H:i'(08.06.2013 12:00)

我尝试了几件事,最后一件是:

SELECT * FROM `events` WHERE DATE_FORMAT(SUBSTRING(enddate,1,9),'%Y%m%d') >= DATE_FORMAT(CURDATE(),'%Y%m%d')
我认为这将转化为:(日期=27.08.2013)

但它现在起作用了。。。我得到了太多的结果:-/

任何帮助都将不胜感激


谢谢

您应该尝试使用
STR\u TO\u DATE
()

STR_TO_DATE
根据给定的格式解析字符串(
'%Y.%m.%d'
,在您的情况下),并返回可用于MySQL的日期字符串。转换后,您可以将其与其他日期值或函数(如
CURDATE
)进行自由比较。您应该阅读文档以了解更多详细信息


从长远来看,您最好使用实际的
DATE
DATETIME
列。

您必须将日期格式更改为适当的格式。
SELECT * FROM `events` WHERE 20130827 >= 20130608
SELECT * FROM `events` WHERE STR_TO_DATE(enddate, '%Y.%m.%d') >= CURDATE();