2010-11-13 24 views
23

Próbuję powiązać parametry użytkowe dla zapytania SQL wewnątrz pętli:wiążące params do rachunku PDO wewnątrz pętli

$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> 
} 

Powyższy kod wkładek w bazie we wszystkich 3 polach 2010-whatever.

Ten działa prawidłowo:

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

Więc moje pytanie brzmi: dlaczego kod w foreach pętli nie powiedzie się i wstawia błędnych danych w polach?

Odpowiedz

41

Problem polega na tym, że numer bindParam wymaga odwołania. Powiązanie zmiennej z instrukcją, a nie z wartością. Ponieważ zmienna w pętli foreach jest rozbrajana na końcu każdej iteracji, nie można użyć kodu w pytaniu.

można wykonać następujące czynności, używając odniesienia w 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 
} 

Albo można to zrobić, używając bindValue:

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

Witam Ionesomeday - Ja wpadłem na podobny problem . Czy mógłbyś mi pożyczyć rękę? http://stackoverflow.com/questions/34285341/php-function-procedure-to-ind-question-marks-dynamicznie – usert4jju7

+0

Pytanie brzmi - który z nich jest lepszy? bindValue lub bindParam. –

+1

@IdanMagled Tutaj myślę, że 'bindValue' jest bardziej intuicyjny. 'bindParam' ma zalety w pewnych okolicznościach. – lonesomeday