好的,因此我的数据库按此顺序如下:

id(主要-auto_increment),用户名(唯一),密码,fname,邮件

我有它,以便用户注册用户名和密码,并将其首先添加到数据库中。用户名不能相同,当确实将数据添加到数据库时,它会自动增加ID。所有这些都有效,但是现在我创建了一个帐户设置页面,用户可以在其中更改其电子邮件和名字,但是它不起作用。我让用户在一页上的表单中输入变量,并且将其名字发布为ufname(用于更新名字)和umail(用于更新邮件)。然后在更新数据库的下一页上,我有以下代码:

session_start();
if(!isset($_SESSION['userId'])) {
die("&nbsp;You are not signed in. Please <a href='login.php'>click here</a> to sign in.");
} else {
$changeTXT = $_SESSION['username'];
$changeTXT = strtolower($changeTXT);
$changeTXT = ucfirst($changeTXT);
echo "Account Settings: <font color='red'>" . $changeTXT . "</font><br /><br />";

$ufname = $_POST['ufname'];
$umail = $_POST['umail'];

mysql_connect("localhost", "root", "sp1151") or die(mysql_error());


mysql_select_db("usersys") or die(mysql_error());

mysql_query("INSERT INTO userdb (id, username, password, fname, mail) VALUES('','','','$ufname', '$umail') ");


echo $umail . "<br /><br />";
echo $ufname;

}

哦,我也让用户登录了 session 。

但是,如何将用户输入的名字和电子邮件插入数据库中的特定行?我的数据库名称是userdb。

最佳答案

您需要运行UPDATE查询来更改现有行,而不是INSERT。

$sql = "UPDATE userdb SET fname = '$ufname', mail = '$umail' WHERE id = $id";
mysql_query($sql);

09-25 18:24
查看更多