PDO-Bindungswerte für MySQL IN-Anweisung
Bei der Arbeit mit PDO kann das Binden eines Arrays von Werten an eine MySQL IN-Anweisung zu unerwarteten Ereignissen führen Verhalten. Standardmäßig behandelt PDO die gebundenen Werte als einzelne Zeichenfolge, was zu einer Abfrage führt, bei der die IN-Anweisung für die gesamte Zeichenfolge und nicht für die einzelnen Werte verwendet wird.
Problem:
Um das Problem zu veranschaulichen, betrachten Sie den folgenden Code:
// Array of values $values = array(1, 2, 3, 4, 5, 6, 7, 8); // Database-safe variable $products = implode(',', $values); // PDO statement $stmt = $conn->prepare("SELECT users.id FROM users JOIN products ON products.user_id = users.id WHERE products IN (:products)"); // Bind the values $stmt->bindParam(':products', $products);
In diesem Fall wird die resultierende Abfrage ausgeführt sein:
SELECT users.id FROM users JOIN products ON products.user_id = users.id WHERE products IN ('1,2,3,4,5,6,7,8')
Diese Abfrage behandelt effektiv die gesamte Zeichenfolge als eine einzelne Bedingung, was nicht das beabsichtigte Verhalten ist.
Lösung:
Um dieses Problem zu beheben, stehen mehrere Optionen zur Verfügung:
SELECT users.id FROM users JOIN products ON products.user_id = users.id WHERE find_in_set(cast(products.id as char), :products)
Dieser Ansatz erfordert die Umwandlung der Werte in einen Zeichentyp, was sich auf die Leistung großer Datenmengen auswirken kann.
Zusätzliche Hinweise:
Das obige ist der detaillierte Inhalt vonWie binde ich Array-Werte mithilfe von PDO korrekt an eine MySQL IN-Anweisung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!