写入数据库时$sql in a while循环


Writing to the database with $sql in a while loop

我希望你能帮助我解决php数据库问题。

------这里是 php 文件减去数据库信息-------------

// Connect to server and select database
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select database");
// read data
    $query="SELECT * FROM $tbl_name ORDER BY ID ASC";
    $result=mysql_query($query);
// Start loop
$i=0;
$num=10;
while ($i < $num) {
$ID=mysql_result($result,$i,"ID");
$notes=mysql_result($result,$i,"notes");
$InStitches=mysql_result($result,$i,"InStitches");
$notes=mysql_result($result,$i,"notes");
echo"i=$i, ID=$ID | InStitches=$InStitches | notes=$notes";
if($notes=="In Stitches game"){
    // update data in mysql database 
    echo "<font color='"#0000FF'"> || $ID yes ||</font>";
    $sql="UPDATE $tbl_name SET InStitches='yes' WHERE ID='$ID'";
    $ID2=mysql_result($result,$i,"ID");
    $InStitches2=mysql_result($result,$i,"InStitches");
    echo " || $ID2 $InStitches2 ||";
}
echo" - done<br/>";
// Increase value of i and continue loop
$i++;
}

---- 以下是我的显示器上显示的故障排除结果---

i=0, ID=1 | InStitches=yes4 | notes=this is a note - done
i=1, ID=2 | InStitches=yes4 | notes= - done
i=2, ID=11 | InStitches= | notes= - done
i=3, ID=12 | InStitches= | notes=tester, In Stitches game - done
i=4, ID=14 | InStitches=22 | notes=In Stitches game || 14 yes || || 14 22 || - done
i=5, ID=15 | InStitches= | notes= - done
i=6, ID=16 | InStitches= | notes= - done
i=7, ID=17 | InStitches= | notes= - done
i=8, ID=18 | InStitches= | notes=blog tour winner, tester - done
i=9, ID=19 | InStitches= | notes=tester - done

对于 i=4 (ID=14(

">

InStitches"字段为"22",将在数据库中更改为"yes"。 但它不会改变。 它保持22。

我正在其他 php 文件中使用 $sql 语句,它工作得很好。 此脚本的唯一区别是我在 while 循环中具有 $sql 语句。 所以我在互联网上搜索了又搜索,看看是不是因为我在一段时间循环中得到了$sql语句。 我找不到任何地方都认为这是问题所在。 我已经在这个脚本上工作了 8 个多小时,而且在我的智慧尽头。

知道为什么它不写入数据库吗?

您没有执行更新语句!

$sql="UPDATE $tbl_name SET InStitches='yes' WHERE ID='$ID'";
$ID2=mysql_result($result,$i,"ID");

应该是

$sql="UPDATE $tbl_name SET InStitches='yes' WHERE ID='$ID'";
$result=mysql_query($sql);