在MySQL datetime中插入变量


Inserting variable into MySQL datetime

我从用户输入中获取日期和时间,然后尝试将给定的日期和时间插入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";