MySQLi query to loop through array and update multiple rows(MySQLi查询以循环遍历数组并更新多行)
本文介绍了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");
}
}
如果不特别知道有多少个数组键,并将其全部保存在一个查询中,那么执行此操作的最简单方法是什么?
pdo
注意:我的答案是基于推荐答案驱动程序,它在很多方面都比mysqli更好。如果您需要mysqli解决方案,请查看the other answer provided by @Your Common Sense
以下代码在真实环境中进行了测试,并与阻止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注入的更多详细信息,请阅读:
https://www.owasp.org/index.php/SQL_Injection
这篇关于MySQLi查询以循环遍历数组并更新多行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:MySQLi查询以循环遍历数组并更新多行
基础教程推荐
猜你喜欢
- 超薄框架REST服务两次获得输出 2022-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- 在多维数组中查找最大值 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01