Aktualizowanie wielu kolumn tabeli MySQL przy użyciu tablic z PDO
Próbuję przełączyć wszystkie moje połączenia MySQL ze starego mysql_query na PDO. Usiłuję zaktualizować wiele wierszy i kolumn tabeli MySQL przy użyciu różnych tablic i otrzymuję następujący błąd:
[42000]: Błąd składni lub naruszenie dostępu: 1064 Wystąpił błąd w składni SQL; sprawdź instrukcję, która odpowiada twojej wersji serwera MySQL, pod kątem prawidłowej składni, aby używać wartości zbliżonych do „(accnt, car, radio, misc)” („admin”, „300.00”, „400.00”, „10 .00”) WHERE ID ”w linii 1
Z następującego kodu:
$account = $_POST['account'];
$car_lease = $_POST['car_lease'];
$radio_lease = $_POST['radio_lease'];
$misc_lease = $_POST['misc_lease'];
$lease_ID = $_POST['lease_ID'];
//$data = array_map(null,$account,$car_lease,$radio_lease,$misc_lease);
$A = count($lease_ID);
try {
$DBH = new PDO("mysql:host=$host;dbname=$dbname", $user, $pass);
$DBH->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$STH = $DBH->prepare('UPDATE lease (accnt, car, radio, misc) values (:account, :car_lease, :radio_lease, :misc_lease) WHERE ID = :lease_ID');
$i = 0;
while($i < $A) {
$STH->bindParam(':account', $account[$i]);
$STH->bindParam(':car_lease', $car_lease[$i]);
$STH->bindParam(':radio_lease', $radio_lease[$i]);
$STH->bindParam(':misc_lease', $misc_lease[$i]);
$STH->bindParam(':lease_ID', $lease_ID[$i]);
$STH->execute();
$i++;
}
}
catch(PDOException $e) {
echo "I'm sorry, but there was an error updating the database.";
file_put_contents('PDOErrors.txt', $e->getMessage(), FILE_APPEND);
}
Uważam, że ten problem wynika ze sposobu wywoływania uchwytu instrukcji, ale nie jestem pewien, która część mojej składni jest niepoprawna. Czy jest to najlepszy sposób radzenia sobie z takimi sytuacjami? Czy istnieje lepsza metoda aktualizacji wielu wierszy w tabeli?