使用时,
strotime()请确保使用有效的datetime格式。否则
strtotime()会返回
false
或 给您一个意外的值。
假定使用XX / XX /
XXXX格式的日期为美国格式,这意味着前两位数字代表月份,后两位数字代表月份,后四位代表年份。使用破折号时,日期假定为欧洲格式。例如:
04/18/2017 = April 18, 201712/18/2017 = December 18, 201718-04-2017 = April 18, 201718-12-2017 = December 18, 2017
如果您不小心切换了日期和月份
strtotime(),则日期将返回false,因为日期无效。
18/04/2017 // error18/12/2017 // error04-18-2018 // error12-18-2017 // error
上面的例子很简单。但是,当日期不确定时,您可能会遇到问题。例如:
04/12/2017 = April 12, 201712/04/2017 = December 4, 201704-12-2017 = December 4, 201712-04-2017 = April 12, 2017
在上面的示例中,通过切换日期和月份,我们仍然可以获得有效的日期,这可能会在您的应用程序中导致意外的结果。为了解决这些潜在的问题,建议使用
DateTime::createFromFormat()解析日期并返回一个
DateTime()对象,您可以从该对象获得Unix时间戳,将日期转换为另一种格式,或者将其与其他
DateTime对象进行比较。
// Parse US date format$date1 = DateTime::createFromFormat('m/d/Y', '04/18/2017');// Get Unix timestamp of 1493581268$timestamp = $date1->getTimestamp();// Parse European date format$date2 = DateTime::createFromFormat('d-m-Y', ''18-04-2017);// Get MySQL format (ISO-8601) of 2017-04-18$mysqlDate = $date2->format('Y-m-d');也可以看看:
- 使用PHP中的比较运算符比较DateTime对象
对于您的特定情况,以下代码将起作用:
$date = $date1 = DateTime::createFromFormat('m/d/Y', '20/02/2000');$D->query = $date->format('Y-m-d'); // 2000-02-20


