将多个复选框和文本框数组插入 MySQL 数据库:解决常见问题
涉及多个复选框和文本框数组的查询可能会给 PHP 带来挑战。本文解决了两个具体问题:为什么复选框显示为已选中(即使未选中),以及为什么数据无法插入数据库。
复选框显示问题
罪魁祸首是使用 implode,它会生成所有复选框值的逗号分隔字符串。无论是否选中特定复选框,此方法都会错误地将整个列表插入到每个数据库行中。
要纠正此问题,请为表单 HTML 中的复选框名称分配显式索引。通过这样做,$_POST['checkbox'] 数组中相应的复选框值可以轻松地与其随附的 $_POST['item'] 和 $_POST['quantity'] 元素相关联,而无需依赖内爆。
数据库插入失败
由于复选框仅提交选中项的值,因此出现了另一个问题。这会导致 $_POST['checkbox'] 数组的索引与相应的 $_POST['item'] 和 $_POST['quantity'] 元素之间不匹配。
要解决此问题,请使用分配给修改后的表单中的复选框名称的索引。这允许正确的值配对,确保数据库中的每一行都包含正确的数据集。
此外,不要使用 mysql_query,而是使用 $conn->query() 方法,该方法是与用于数据库连接的 MySQLi API 一致。
更新了 PHP 代码:
<br>$stmt = $conn->prepare("插入购买(产品、数量、价格)值 (?, ?, ?)");<br>$stmt->bind_param("sis", $name, $quantity, $price);<br>foreach ( $_POST['checkbox'] as $i => $price) {<pre class="brush:php;toolbar:false">$name = $_POST['name'][$i]; $quantity = $_POST['quantity'][$i]; $stmt->execute();
}
额外安全措施
作为安全预防措施,通常建议从数据库中检索价格,而不是将其存储在 HTML 中。这可以防止用户在提交表单之前在网络检查器中修改价格。
以上是如何将多个复选框和文本框数组插入 MySQL 数据库:解决常见问题的详细内容。更多信息请关注PHP中文网其他相关文章!