Estou curioso para saber se é possível vincular uma matriz de valores a um espaço reservado usando o PDO. O caso de uso aqui está tentando passar uma matriz de valores para uso com uma IN()
condição.
Eu gostaria de poder fazer algo assim:
<?php
$ids=array(1,2,3,7,8,9);
$db = new PDO(...);
$stmt = $db->prepare(
'SELECT *
FROM table
WHERE id IN(:an_array)'
);
$stmt->bindParam('an_array',$ids);
$stmt->execute();
?>
E faça com que o PDO ligue e cite todos os valores na matriz.
No momento eu estou fazendo:
<?php
$ids = array(1,2,3,7,8,9);
$db = new PDO(...);
foreach($ids as &$val)
$val=$db->quote($val); //iterate through array and quote
$in = implode(',',$ids); //create comma separated list
$stmt = $db->prepare(
'SELECT *
FROM table
WHERE id IN('.$in.')'
);
$stmt->execute();
?>
O que certamente faz o trabalho, mas me pergunto se há uma solução embutida que estou faltando?