php-使用准备好的语句删除带有PDO和复选框的多行?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php-使用准备好的语句删除带有PDO和复选框的多行?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1359字,纯文字阅读大概需要2分钟。
内容图文
![php-使用准备好的语句删除带有PDO和复选框的多行?](/upload/InfoBanner/zyjiaocheng/673/cd9db132944645d0b1dc3b5864d130ff.jpg)
我有这段代码,
$q = $dbc -> prepare ("SELECT * FROM tasks ORDER BY date_time LIMIT 0, 15");
$q -> execute();
echo '<form action="/adminpanel?tab=process" method="post">
<input type="hidden" name="deletetask" />';
while ($todo = $q -> fetch(PDO::FETCH_ASSOC)) {
echo '<div id="update"><div><strong>'
. $todo['date_time'] . '</strong><span>' . $todo['type']
. '</span></div><p>' . $todo['message']
. '</p><input class="checkbox" name="deletetask" value="'
. $todo['date_time'] . '" type="checkbox" /></div>';
}
echo '<input type="submit" value="Delete Tasks" /></form>';
现在,除了一件事之外,一切都按预期工作,我在互联网上还没有真正找到任何答案.我的while循环将总是有多于一行,并且几乎总是希望从中删除多于一行.
按照此脚本的形式,表单可以工作,但只会删除最后单击的复选框.我了解为什么这样做,但是我不了解如何使用PDO和准备好的语句来解决此问题.
解决方法:
您正在为每个复选框分配相同的名称=“ deletetask”.因此,提交表单时,您只会收到最后选择的deletetask值.所以,你的错误在这里
<input class="checkbox" name="deletetask" value=
应该
<input class="checkbox" name="deletetask[]" value=
因此,您需要将deletetask重命名为deletetask [],以便您的复选框作为数组发送,而不是像
$todelete = $_POST['deletetask'];
//or $_GET, if you are submitting form through get. But I would recommend you using POST
$stmt = $pdo->prepare("DELETE FROM table WHERE id = ?");
foreach ($todelete as $id)
$stmt->execute($id);
内容总结
以上是互联网集市为您收集整理的php-使用准备好的语句删除带有PDO和复选框的多行?全部内容,希望文章能够帮你解决php-使用准备好的语句删除带有PDO和复选框的多行?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。