首页 >后端开发 >php教程 >如何将多个复选框和文本框数组插入 MySQL 数据库:解决常见问题

如何将多个复选框和文本框数组插入 MySQL 数据库:解决常见问题

Patricia Arquette
Patricia Arquette原创
2024-10-30 11:10:121057浏览

  How to Insert Multiple Checkbox and Textbox Arrays into a MySQL Database: Addressing Common Issues

将多个复选框和文本框数组插入 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn