我正在使用 AJAX 和 JSON 更新数据库,但数据库中的值没有更新。
我知道发送了正确的值,并且返回了正确的值,但我的 MySQL 更新没有执行任何操作。它位于 if
语句内。
PHP
$youruname = mysql_real_escape_string($_POST['youruname']);
$selectedplayer = mysql_real_escape_string($_POST['selectedplayer']);
$flag = "";
$itStatus = "";
$checkit = mysql_query("SELECT it FROM login WHERE uname='$selectedplayer'");
while($row = mysql_fetch_array($checkit))
{
$itStatus = $row['it'];
}
if($itStatus === "not it")
{
mysql_query("UPDATE login SET it='not it' WHERE uname = '$youruname'");
mysql_query("UPDATE login SET it='it' WHERE uname = '$selectedplayer'");
$flag = "success";
}
else if($itStatus === "it")
{
$flag = "nope";
}
else
{
$flag = "error";
}
echo json_encode(array("message" => $flag, "tagged" => $selectedplayer));
最佳答案
这可能不是您问题的一部分,但您可以将其合并为一个,而不是执行两个更新语句,
UPDATE login SET it='not it' WHERE uname = '$youruname'
UPDATE login SET it='it' WHERE uname = '$selectedplayer'
进入
UPDATE login
SET it = CASE WHEN uname = '$youruname' THEN 'not it' ELSE 'it' END
WHERE uname IN ('$youruname', '$selectedplayer')
关于php - MySQL 更新无法使用 If 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16884777/