中复制这一理论
我有一个对象数组:
$arr = array('10', '12');
我正在使用PDO:运行这个查询
$stmt = $pdo->prepare("SELECT * from table WHERE user_sequence = :user_sequence");
我想让查询说WHERE user_sequence = :item1 OR user_sequence = :item2
item1, item2
等是来自阵列的对象
我如何使用PDO做到这一点?
通常在MySQL中,我会做:
$sql="SELECT * from table WHERE ";
foreach($array as $a) {
$sql.="col = '".$a."' OR ";
}
但我不确定如何在PDO查询
你可以这样做:
$values = [ 'first value', 'second value', 'third value' ];
$conds = array_map(function() {
return "user_sequence = ?";
}, $values);
$sql = "SELECT * from table WHERE " . implode(" OR ", $conds);
$stmt = $pdo->prepare($sql);
$stmt->execute($values);