如何动态使用mysqli bind_param


How to use mysqli bind_param dynamically

我有一个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);
}