MySQL 按行[id]使用新信息更新“n”行数


MySQL Update 'n' number of rows with new info by row[id]?

好的,我有一个php文件的集合,作为一个基于Web的库存系统。搜索项目并从列表中选择一个项目后,用户将转到一个页面,该页面显示以前所选项目的 当前数量。在同一页上,javascript 用于对当前数量值进行加法或减法。我希望能够在当前数量文本框中获取更新的值,并在MySQL中更新它们。

请注意,显示的项目数因搜索页面上选择的数量而异。

以下是更新页面,用户可以在其中添加或减去数量值:

<html>
<title>Update Selections</title>
<body>
<?php
    include("menu.php");
    include("sqlconnect.php");

?>
<script type="text/javascript">
/*<![CDATA[*/
function add(obj,ud){
 while (obj.parentNode){
  if (obj.nodeName.toUpperCase()=='TR'){
   obj=obj.getElementsByTagName('INPUT')[0];
   break;
  }
  obj=obj.parentNode;
 }
 if (obj.nodeName.toUpperCase()=='INPUT'){
  obj.value=Math.max(obj.value*1+ud,0);
 }
}

/*]]>*/
</script></head>

<p align="center"><b>Make Updates:</b>
<br />
<br />
The following items were selected for quantity update:
<br />
<br />
<table border="1">
<tr><th>Item:</th>
<th>QUANTITY</th>
<th>ADD/SUBTRACT</th></tr>
<style>
textarea {resize: none;}
</style>
<form action="updatequantityprocess.php" method="post">
<?php
        //$row_id = $_POST['itemselect'];
        foreach ($_POST['itemselect'] as $confirm)
        {
            $result = mysql_query("SELECT * FROM inventory WHERE id='$confirm'");
            while ($row = mysql_fetch_array($result))
            {
                echo "<tr><td>" . $row['Item'] . "</td>";
                echo "<td bgcolor='grey'><input type='text' id='value' name='itemupdate[]' disabled='disabled' style='text-align: center' value='" . $row['QuaninInventory'] . "'><input type='hidden' value='" . $row['id'] . "' name='itemid[]'></td>";
                echo "<td><div align='center'><input type='button' value='+' onclick='add(this, 1)'><input type='button' value='-' onclick='add(this, -1)'></div></td></tr>";
            }
        }
        echo "</table>";
?>
<br />
<br />
<input type="submit" value="Update">
<br />
<INPUT TYPE="BUTTON" VALUE="<-- Back to Results" ONCLICK="window.location.href='http://localhost/Inventory/quantitybybrandprocess.php'">
</p>
</form>
</body>     
</html>

我不知道如何使用itemupdate[]item[]数组来构建下一页,quantityupdateprocess.php ,以更新 MySQL 数据库中的选定项目。

使用 foreach 循环遍历所有 itemid,并单独更新每个 itemid。

foreach($_POST["itemids"] as $itemid){
    //Do mysql update based on other fields (make sure to escape itemid, and the other fields as well, or even better use prepared statements).
}

为了访问当前项目的数量,请执行如下操作。

foreach($_POST["itemids"] as $i=>$itemid){
    //do mysql updates where $_POST["itemupdate"][$i] is the item update for the item id.
}

我将根据您的问题标题以更简单的方法呈现它:

首先,强烈建议不要使用mysql扩展,而是使用 PHP PDO

例:

$DBH = new PDO('mysql:host=http://yourhost.com;dbname=yourdbname;charset=utf8', 'username', 'password');
$DBH->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$STH = $DBH->prepare('INSERT INTO `yourtable` (`column1`, `column2`) VALUES (?, ?)');
foreach($array as $value) {
    $STH->bindParam(1, $value);
    $STH->bindParam(2, $value);
    $STH->execute();
}
$DBH = null;

您可以使用自动转义所有无效或有问题的字符的prepared statements。您还可以制作预准备语句并重复使用它来插入大量数据,同时优化整个过程。

您可以在phpro.org的PDO教程页面上找到更多信息。它们解释得很好。

关于您的问题,在这种情况下,您可能必须实现这样的东西:

假设您收到一个通过 $_POST id => values[]形式的数组,因此您的查询将如下所示:

$DBH = new PDO('mysql:host=http://yourhost.com;dbname=yourdbname;charset=utf8', 'username', 'password');
$DBH->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$STH = $DBH->prepare('UPDATE `yourtable` SET `column1` = ?, `column2` = ? WHERE `id` = ?');
foreach($array as $id => $values) {
    $STH->bindParam(1, $values[0]);
    $STH->bindParam(2, $values[1]);
    $STH->bindParam(3, $id);
    $STH->execute();
}