html 表格中 Mysql 数据库中记录为 0000-00-00 的日期值

Date value recorded as 0000-00-00 in Mysql database from html form

我知道同一个问题已经被问过好几次了,但我似乎无法理解 it.I 已经完成了我找到的所有解决方案,但它对我的情况不起作用。“日期”正在在 Mysql 数据库中记录为 0000-00-00 而不是正确的 date.Here 是 PHP 代码。`

// initialize variables

$Vehicle_name = "";
$Vehicle_make = "";
$Vehicle_color="";
$Number_plate = "";
$Driver_name = "";
$Number_of_passengers = "";
$Date = "";
$Time = "";
$Security = "";


$id = 0;
$update = false;

if (isset($_POST['save'])) {

    $Vehicle_name = $_POST['Vehicle_name'];
    $Vehicle_make = $_POST['Vehicle_make'];
    $Vehicle_color = $_POST['Vehicle_color'];
    $Number_plate = $_POST['Number_plate'];
    $Driver_name = $_POST['Driver_name'];
    $Number_of_passengers = $_POST['Number_of_passengers'];
    $Date = $_POST['Date '];
    $Time = $_POST['Time'];
    $Security = $_POST['Security'];


    mysqli_query($db, "INSERT INTO vehicle (Vehicle_name,Vehicle_make,Vehicle_color,Number_plate,Driver_name,Number_of_passengers,Date,Time,Security ) VALUES ('$Vehicle_name','$Vehicle_make','$Vehicle_color','$Number_plate','$Driver_name','$Number_of_passengers','$Date','$Time','$Security ')"); 
    $_SESSION['message'] = "Car registered"; 
    header('location: welcome.php');
}`.

这也是日期文本框代码。

<div class="input-group"> <label>Date :</label> <input type="date" name="Date" value="" required="yes" > </div>.

我花了很多时间想弄清楚,但都是徒劳的,请help.Regards。

如果您的数据库字段的数据类型是 date 那么您可以更改下面的代码行

$Date = date('Y-m-d', strtotime($_POST['Date']));

如果您的数据库字段的数据类型是 datetime 那么您可以更改下面的代码行

$Date = date('Y-m-d H:i:s', strtotime($_POST['Date']));

在这里我可以看到你在另一个字段中分隔时间然后你可以更改下面的代码行

$Time = date('H:i:s', strtotime($_POST['Time']));

您的密钥中有space

$Date = $_POST['Date '];

改为

$Date = $_POST['Date'];

您传递参数的方式会导致 SQL 注入。请阅读它 here