Php MySQLi查询以循环遍历数组并更新多行

Php MySQLi查询以循环遍历数组并更新多行,php,mysqli,Php,Mysqli,我有这样一个数组: $postdata[1] = 'This'; $postdata[2] = 'That'; $postdata[3] = 'The other'; 我想在数组中循环并更新ID对应于数组键的所有行。比如: foreach ($postdata as $key => $value) { if ($key == 1) { $update = $db->query("UPDATE site_email_templates SET Content='$post

我有这样一个数组:

$postdata[1] = 'This';
$postdata[2] = 'That';
$postdata[3] = 'The other';
我想在数组中循环并更新
ID
对应于数组键的所有行。比如:

foreach ($postdata as $key => $value) {
  if ($key == 1) {
    $update = $db->query("UPDATE site_email_templates SET Content='$postdata[1]' WHERE ID = 1");
  } else if ($key == 2) {
    $update = $db->query("UPDATE site_email_templates SET Content='$postdata[2]' WHERE ID = 2");
  } else if ($key == 3) {
    $update = $db->query("UPDATE site_email_templates SET Content='$postdata[3]' WHERE ID = 3");
  }
}

最简单的方法是什么,不知道有多少个数组键,并将其保存在一个查询中?

注意:我的答案基于PDO驱动程序,它在许多方面都优于mysqli。如果您需要mysqli解决方案,请检查

下面的代码在真实环境中进行了测试,并提供了防止SQL注入的预处理语句:

$sql = "UPDATE `site_email_templates` SET `Content` = (:content) WHERE `Id` = (:id)";
$stmt = $dbConn->prepare($sql);
foreach ($postdata as $id => $content)
{
    $stmt->execute([':id' => $id, ':content' => $content]);
}
有关SQL注入的更多详细信息,您可以阅读更多内容:

您需要使用预先准备好的语句,以避免各种错误和漏洞,并获得一些较小的性能增益

$stmt = $db->prepare("UPDATE site_email_templates SET Content=? WHERE ID = ?");
$stmt->bind_param("ss", $content, $id);
foreach ($postdata as $id => $content)
{
    $stmt->execute();
}

参考资料:

不知何故,这个答案的风流韵事是最后一根稻草。该系统必须是多么糟糕,只有通过元帖子手动处理才能工作。。。