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='$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");
  }
}

执行此操作的最简单方法是什么,而不是特别知道有多少个数组键,并将其全部保存在一个查询中?

最佳答案

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

$stmt = $db->prepare("UPDATE site_email_templates SET Content=? WHERE ID = ?");
$stmt->bind_param("ss", $content, $id);
foreach ($postdata as $id => $content)
{
    $stmt->execute();
}
引用:How can I prevent SQL injection in PHP?

关于php - MySQLi 查询循环遍历数组并更新多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31830638/

相关文章:

javascript - 使输入元素不可见

php - 无法将有效变量传递给查询

php mysql 获取计数 WHERE BETWEEN AND

如果未启用 mysqli,PHP 不会抛出异常

php - 在html表中显示数据库表中的所有数据

php - MySQLi,PHP-尝试{…}捕获(…){…}不起作用

php - while 循环并连接 mysql php 中的输出

php - 这个php代码有什么问题?

php - 如何检查 PCNTL 模块是否存在

php - 什么是 Unix 时间戳以及为什么要使用它?