用PHP删除MySQL数据库中多行的更好方法?
假设我有一个数组,其中包含一组MySQL表的ID:
$idList = array('1','2','3','4','5');
我想删除与每个id相关联的行。哪种方法更可取/更好/更快?
$idListString = implode(",",$idList);
mysql_query("DELETE FROM this_table WHERE id IN ($idListString)");
或
foreach($idList as $value) {
mysql_query("DELETE FROM this_table WHERE id = '$value'");
}
解决方案
我不是专家,但我相信
$idListString = implode(",",$idList);
mysql_query("DELETE FROM this_table WHERE id IN ($idListString)");
更快。原因是,它只进行一次查询。发送到服务器的数据更少,并且只需一次命令即可处理所有数据。
一般来说,对于另一种方法,如果您有300个值,这意味着您要进行300个额外的函数调用,300个与服务器的通信,等等,尽管在实践中可能会有所不同。
编辑:此外,您应该始终使用适当的MySQL转义,即使您可以确定数据不是恶意的。请参阅http://php.net/manual/en/function.mysql-real-escape-string.php并考虑使用mysqli或pdo。
相关文章