我有一个mysqli查询,它的where子句是在for循环中生成的。因此,参数在运行时之前是未知的。
在这种情况下,我如何使用mysqli bind_param方法?
我可以在for循环中使用它来逐个绑定参数吗?
是的,使用php5.6是可能的,而且非常简单,首先你需要知道你能帮助多少参数str_repeat()
、count()
,以及拆包运算符(...
),所以这种方式可以使绑定dynimic。
$params = [10, 50, 51, 99];
$types = str_repeat('i',count($params));
$stmt = $mysqli->prepare("SELECT * FROM t WHERE id IN (?,?,?,?)");
$stmt->bind_param($types, ...$params);
if(!$stmt->excute()){
echo mysqli_error($con);
}