PHP的; mysql;如何插入user_id或date_created?

时间:2017-03-20 08:32:11

标签: php mysql registration

我制作了一份简单的登记表。我应该如何编辑此表单以添加如下内容:user_id或date_created? 当我将user_id列添加到PHPMyAdmin时,用户无法注册,但是当我只有值时:'First Name'; '姓' ; '电子邮件';数据库内的“密码”,一切正常。

    <!DOCTYPE html>
<html>
<head>
    <title>Registration</title>
</head>
<body>
<?php
$lclhost = "localhost";
$pass = "";
$root = "root";
$database = "regis";
$con=mysqli_connect ("$lclhost", "$root", "$pass") or die("connection fail".mysql_error());
mysqli_select_db($con, $database) or die("database fail".mysql_error());
?>
<form method="get">
    First Name : <input type="text" name="fname"><br>
    Last Name : <input type="text" name="lname"><br>
    Email: <input type="text" name="email"><br>
    Password: <input type="Password" name="password">
    <input type="submit" name="btnsubmit">
</form>
<?php 
if (isset($_GET['btnsubmit']))
{
    $fname = $_GET['fname'];
    $lname = $_GET['lname'];
    $email = $_GET['email'];
    $password = $_GET['password'];
    $registration = "INSERT INTO tbl_info values ('".$fname."','".$lname."','".$email."','".$password."')";
    mysqli_query($con,$registration);
    echo "Succes!";
}
?>
</body>
</html>

1 个答案:

答案 0 :(得分:0)

由于您的查询未指定列,因此只有在您提供的列值数与数据库中的列数完全相同时,mysql才会起作用。

向数据库添加一个额外的列将导致查询中断,因为列数不再相同。

您有两种选择:

选项1:在查询中添加列名:

 "INSERT INTO tbl_info(Firstname, Lastname, EmailAddress, Password)   
  values ('".$fname."','".$lname."','".$email."','".$password."')";  

选项2:始终确保数据库中的列数与您在查询中提供的值的数量完全相同

  

NB:如果您有自动增量ID字段,则不必将其包含在第一个选项中,因为每当您插入记录时它都会自动添加值。但是你需要将它包含在第二个选项中,传递空字符串或null作为值