MySQL更新不使用If语句


MySQL Update Not Working With If Statement

我正在使用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语句,

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')

好了,我想明白了。

我正在调用数据库,试图选择一个不存在的值。

基本上,我在寻找错误的值。

我的代码是正确的。

对所有提供帮助的人,我表示感谢。