无法使用PHP从MySQL数据库更新记录

时间:2015-03-05 11:02:01

标签: php mysql

我尝试使用PHP代码更新MySQL数据库中的记录。问题是,如果只有一条记录,则更新正在进行,但对于表中的多条记录,相同的代码不会更新任何记录。我不知道为什么。以下是来自edit.php页面的PHP代码的一部分('用户可能会产生混淆;它是关于管理员用户使用他的密码记录并可以更改其他用户的数据)

session_start();
$user = $_SESSION['username'];
$pass = $_SESSION['password'];

if (isset($_POST ['updateuser'])){
$UpdateQuery="UPDATE user SET email='$_POST[email]', name='$_POST[name]', surname='$_POST[surname]', grade='$_POST[grd]'";
mysql_query($UpdateQuery, $link);};

if(isset($_POST ['Edit']))
{ $sql = "SELECT * FROM user WHERE idUser = '$user'";
  $p = mysql_query($sql, $link);
  echo '<table border=1 >
  <tr>
  <th>email</th>
  <th>name</th>
  <th>surname</th>
  <th>grade</th>
  </tr>';
  while($record=mysql_fetch_array($p)){
  echo '<form action=edit.php method=post>';
  echo '<tr>';
  echo '<td><input type=text  name=email value=" '.$record['email']. '"></td>';
  echo '<td><input type=text name=name value=" '.$record['name']. '"></td>';
  echo '<td><input type=text name=surname value=" '.$record['surname']. '"></td>';
  echo '<td><input type=text name=grd value=" '.$record['grade']. '"></td>';
  echo '<td><input type=hidden name=hidden value=" ' .$record['idUser']. '"></td>';
   echo '<td><input type=submit name=updateuser value=Update></td>';
          echo '</form>';
         }
         echo '</table>';}

2 个答案:

答案 0 :(得分:1)

您忘记在更新查询中添加条件子句。 试试这个

$UpdateQuery="UPDATE user SET email='$_POST[email]', name='$_POST[name]', surname='$_POST[surname]', grade='$_POST[grd]' WHERE idUser = '$user'";

而不是

$UpdateQuery="UPDATE user SET email='$_POST[email]', name='$_POST[name]', surname='$_POST[surname]', grade='$_POST[grd]'";

答案 1 :(得分:0)

您的更新查询没有WHERE子句,请使用类似这样的内容

$UpdateQuery="UPDATE user SET email='$_POST[email]', name='$_POST[name]', surname='$_POST[surname]', grade='$_POST[grd]' WHERE idUser = '$user'";