Связывание параметров для инструкции PDO внутри цикла
Я пытаюсь связать параметры для 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-loop терпит неудачу и вставляет неправильные данные в поля?
Ответы
Ответ 1
Проблема в том, что 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
}