我想更新数据库中的一行。此数据库中只有一行,在此阶段不会添加其他行。
我正在使用这个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查询,您必须始终使用它来寻址要更改的行,请注意