我制作了一份简单的登记表。我应该如何编辑此表单以添加如下内容: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>
答案 0 :(得分:0)
由于您的查询未指定列,因此只有在您提供的列值数与数据库中的列数完全相同时,mysql才会起作用。
向数据库添加一个额外的列将导致查询中断,因为列数不再相同。
您有两种选择:
选项1:在查询中添加列名:
"INSERT INTO tbl_info(Firstname, Lastname, EmailAddress, Password)
values ('".$fname."','".$lname."','".$email."','".$password."')";
选项2:始终确保数据库中的列数与您在查询中提供的值的数量完全相同
NB:如果您有自动增量ID字段,则不必将其包含在第一个选项中,因为每当您插入记录时它都会自动添加值。但是你需要将它包含在第二个选项中,传递空字符串或null作为值