Связывание параметров для оператора PDO внутри цикла - PullRequest
25 голосов
/ 13 ноября 2010

Я пытаюсь связать параметры для SQL-запроса внутри цикла:

$db = new PDO('mysql:dbname=test;host=localhost', 'test', '');  
$stmt = $db->prepare('INSERT INTO entries VALUES (NULL, ?, ?, ?, NULL)');

$title = 'some titile';
$post = 'some text';
$date = '2010-whatever';  

$reindex = array(1 => $title, $post, $date); // indexed with 1 for bindParam

foreach ($reindex as $key => $value) {  
    $stmt->bindParam($key, $value);  
    echo "$key</br>$value</br>";  //will output: 1</br>some titile</br>2</br>some text</br>3</br>2010-whatever</br>
}

Приведенный выше код вставляет в базу данных во всех 3 полях 2010-whatever.

Это работает нормально:

$stmt->bindParam(1, $title);
$stmt->bindParam(2, $post);
$stmt->bindParam(3, $date);

Итак, мой вопрос: почему код в цикле foreach завершается неудачно и вставляет неправильные данные в поля?

1 Ответ

46 голосов
/ 13 ноября 2010

Проблема в том, что bindParam требует ссылки. Он связывает переменную с оператором, а не со значением. Поскольку переменная в цикле foreach не устанавливается в конце каждой итерации, вы не можете использовать код в вопросе.

Вы можете сделать следующее, используя ссылку в foreach:

foreach ($reindex as $key => &$value) {  //pass $value as a reference to the array item
    $stmt->bindParam($key, $value);  // bind the variable to the statement
}

Или вы можете сделать это, используя bindValue:

foreach ($reindex as $key => $value) {
    $stmt->bindValue($key, $value);  // bind the value to the statement
}
...