好的,我的数据库按此顺序如下:
id(主要 - auto_increment),用户名(唯一),密码,fname,邮件
我有它,以便用户注册用户名和密码,并将其添加到数据库,首先.没有用户名可以是相同的,当它确实将数据添加到数据库时,它会自动增加ID.所有这些都有效,但现在我创建了一个帐户设置页面,用户可以在其中更改其电子邮件和名字,但它无法正常工作.我让用户在一个页面上的表单中输入变量,并将其名字发布为ufname(用于更新名字)和umail(用于更新邮件).然后在下一页更新数据库我有这个代码:
session_start(); if(!isset($_SESSION['userId'])) { die(" You are not signed in. Please click here to sign in."); } else { $changeTXT = $_SESSION['username']; $changeTXT = strtolower($changeTXT); $changeTXT = ucfirst($changeTXT); echo "Account Settings: " . $changeTXT . "
"; $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 . "
"; echo $ufname; }
哦,我也有用户登录会话.
但是,如何插入用户输入数据库中特定行的名字和电子邮件?我的数据库名是userdb.
您需要运行UPDATE查询来更改现有行,而不是INSERT.
$sql = "UPDATE userdb SET fname = '$ufname', mail = '$umail' WHERE id = $id"; mysql_query($sql);
你需要使用和UPDATE
声明而不是INSERT
:
UPDATE userdb SET fname = ?, mail = ? WHERE username = ?;
除此之外,您应该认真考虑使用带有查询参数的预准备语句来防止SQL注入attac.