我有这段代码,
$q = $dbc -> prepare ("SELECT * FROM tasks ORDER BY date_time LIMIT 0, 15");
$q -> execute();
echo '
';
while ($todo = $q -> fetch(PDO::FETCH_ASSOC)) {
echo '
. $todo['date_time'] . '
' . $todo['type']. '
' . $todo['message']
. '
}
echo '
';现在,除了一件事之外,一切都按预期工作,我在互联网上还没有真正找到任何答案.我的while循环将总是有多于一行,并且几乎总是希望从中删除多于一行.
按照此脚本的形式,表单可以工作,但只会删除最后单击的复选框.我了解为什么这样做,但是我不了解如何使用PDO和准备好的语句来解决此问题.
解决方法:
您正在为每个复选框分配相同的名称=“ deletetask”.因此,提交表单时,您只会收到最后选择的deletetask值.所以,你的错误在这里
应该
因此,您需要将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);
标签:mysql,php,pdo
来源: https://codeday.me/bug/20191102/1990089.html