1

我想更新我的数据库和这段代码在另一个表上运行良好,但在这里我有一个错误,我看到这条消息:

您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以id在第 4 行的 'WHERE ='588''附近使用正确的语法

<?php
$sel_item = "SELECT * FROM `employees` where id=".$_GET['emp_id'];
$done_item = mysql_query($sel_item);
$get_item = mysql_fetch_array($done_item);

if(isset($_POST['edit']) ){
    $upd= "UPDATE `employees` SET 
    `emp_no`='".$_POST['name']."',
    WHERE `id`='".$_POST['id']."";
    $do_upd = mysql_query($upd) or die(mysql_error());
}
?>


<form action="" method="post" enctype="multipart/form-data">

         <table class="append-row" width="100%" border="0" bgcolor="#006699"  height="60px" align="left" 
        style="padding:0 30px;">
          <tr>

           <td><input type="text" name="name" id="name" placeholder="name"  value="<? php echo $get_item['emp_no'];?>"></td>
          <input type="hidden" name="id" id="id"    value="<?php echo $get_item['id'];?>" >

          <td><input type="submit" name="edit" id="edit" value="edite"></td>    

      </tr>

        </table>

     </form>
4

4 回答 4

3

您在 UPDATE 语句中的 $_POST['id'] 之后缺少结束单引号,并且在 WHERE 条件之前还有一个不需要的逗号。

尝试:

$upd= "UPDATE `employees` SET `emp_no`='".$_POST['name']."' WHERE `id`='".$_POST['id']."'";
于 2013-05-29T16:55:00.973 回答
1

放弃老式的 Mysql 并使用 PDO 使您和您的数据库更容易,但您的问题是WHERE语句前的逗号。

$sql = $pdo->prepare("UPDATE employees SET emp_no = ? WHERE id = ?");
$sql->execute(array($_POST['name'], $_POST['id']));

作为个人喜好,您永远不应该使用波浪号 `,来包围您的项目,如果是这样您不使用关键字,那么您可能应该重命名您的列/表/数据库。

于 2013-05-29T17:01:37.930 回答
1
$upd= "UPDATE `employees` SET `emp_no`='".$_POST['name']."', WHERE `id`='".$_POST['id'].""; 
$do_upd = mysql_query($upd) or die(mysql_error());

你错过了一个'它应该是......

$upd= "UPDATE `employees` SET `emp_no`='".$_POST['name']."', WHERE `id`='".$_POST['id']."'"; 

您也不需要在“WHERE”之前使用逗号

于 2013-05-29T16:55:53.773 回答
0

emp_no='".$_POST['name']."',

逗号破坏了你的 SQL

于 2013-05-29T17:15:57.787 回答