我从用户输入中获取日期和时间,然后尝试将给定的日期和时间插入MySQL中的datetime列。这个似乎不起作用。然而,当我插入NOW()
时,它工作得很好。
我有变量:$year
, $month
, $date
, $hour
和$minute
。
这就是我所做的:
$i_date = "$year";
$month= sprintf("%02s", $month); // These add a leading zero to numbers less than 10
$i_date .= "$month";
$date = sprintf("%02s", $date);
$i_date .= "$date";
$hour = sprintf("%02s", $hour);
$i_date .= "$hour";
$minute = sprintf("%02s", $minute);
$i_date .= "$minute";
$i_date .= "00"; // These are for seconds.
这给了我正确的日期格式。我已经检查了它的回声出来,然后尝试手动插入到数据库中,它的工作。
但是当我试图通过PHP插入$i_date
到datetime列时,它不接受它。
我如何纠正这个?
我想你漏掉了连字符和冒号。格式应为:
Y-m-d H:i:s // PHP format
例如,现在的日期时间:
2013-06-03 21:09:00
因此,在你的代码中:
$i_date = sprintf('%d-%02d-%02d %02d:%02d:00', $year, $month, $date, $hour, $minute);
你可以简化这些重复的sprint:
$mysql_date = sprintf('%04d-%02d-%02d %02d:%02d:%02d', $year, $month, $day, $hour, $minute, $second);
日期的正确格式是YYYY-MM-DD HH:II:SS
,因此您假设$year
保证是四位数字,您应该将其更新为
$i_date = "$year-$month-$date $hour:$minute:00";