使用PHP代码更新SQL行


Update SQL Row with PHP code

我想更新数据库中的一行。此数据库中只有一行,在此阶段不会添加其他行。

我正在使用这个PHP代码,但它没有更新值给我错误:

错误:您的SQL语法有错误;查看与MySQL服务器版本对应的手册,了解在第1行的"(credits)VALUES('')"附近使用的正确语法

这是我的代码

 <?php
 $con = mysql_connect("localhost","stingin_epanic","****");
 if (!$con)
   {
   die('Could not connect: ' . mysql_error());
   }
  mysql_select_db("stingin_epanic", $con);
  $sql="UPDATE avis_credits (credits)
  VALUES
 ('$_UPDATE[credits]')";
  if (!mysql_query($sql,$con))
   {
   die('Error: ' . mysql_error());
   }
 echo "Number added thank you";
 mysql_close($con);
 ?>

我知道这很愚蠢,但真的在这里击球

看看mysql中的UPDATE语法。

UPDATE avis_credits SET credits = 'your_value'

注意

请不要再使用mysql_*函数。切换到mysqli_函数或PDO。mysql_-函数已被弃用,并且将不支持>=PHP 5.5。

回显$sql并查看它的外观。我的猜测是,根据显示的错误,这些值只是空的,请始终进行快速调试。

您不应该使用不推荐使用的mysql_*函数。

您的SQL不正确。

"UPDATE avis_credits set credits = '$_UPDATE[credits]'";

如果你可以使用PDO或mysqli。

<?php
$dsn = "mysql:host=localhost;dbname=stingin_epanic;charset=utf8";
$opt = array(
    PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
);
$pdo = new PDO($dsn,'stingin_epanic','', $opt);
$sql = "UPDATE avis_credits SET credits = ? WHERE some_id = ?";
$stm = $pdo->prepare($sql);
$stm->execute(array($_POST['credits'], $_POST['id']));

假设您有$_POST,而不是任何$_UPDATE

注意WHERE部分。对于UPDATE查询,您必须始终使用它来寻址要更改的行,请注意