Heim > Datenbank > MySQL-Tutorial > Hauptteil

Warum führt das Binden von Arrays an die IN-Klausel von PDO zu falschen Ergebnissen?

Barbara Streisand
Freigeben: 2024-11-22 04:37:46
Original
511 Leute haben es durchsucht

Why Does Binding Arrays to PDO's IN Clause Yield Incorrect Results?

Bind-Parameter für die IN-Klausel mithilfe von PDO: Diskrepanzen auflösen

Bei der Verwendung von Bind-Parametern für die IN-Klausel mithilfe von PDO können unerwartete Ergebnisse auftreten. Insbesondere zeigt der bereitgestellte Code, dass das Binden eines Arrays an die IN-Klausel über bindParam() zu einer ungenauen Zählung führt, wohingegen die Verwendung des Arrays direkt in der Abfrage die gewünschte Ausgabe erzeugt.

Um die Diskrepanz zu verstehen, ist es wichtig, Folgendes zu tun Erkennen Sie, dass die Funktion implode() von PHP ein Array zu einer einzelnen durch Kommas getrennten Zeichenfolge verkettet. Während dies den Anschein erweckt, als würde eine Werteliste für die IN-Klausel erstellt, wird sie von der Datenbank als einzelner Wert wahrgenommen. Folglich sieht die resultierende Abfrage wie folgt aus:

SELECT foo FROM bar WHERE ids IN ('1,2,3')
Nach dem Login kopieren

In diesem Szenario behandelt die Datenbank die gesamte Zeichenfolge als einen einzelnen Wert, was zu einer fehlerhaften Zählung von 1 führt.

Die Lösung liegt in der manuellen Eingabe Erstellen der IN-Klausel innerhalb der Abfrage selbst. Durch die Verwendung des String-Verkettungsoperators ('.') von PHP kann das Array direkt in die Abfrage eingebunden werden:

'SELECT foo FROM bar WHERE ids IN (' . $myArray .')'
Nach dem Login kopieren

Dieser Ansatz stellt sicher, dass die Datenbank jeden Wert im Array als eindeutigen Eintrag erkennt, was zu führt eine genaue Zählung. Es ist wichtig zu beachten, dass es derzeit keine alternative Methode zum Binden von Parametern für die IN-Klausel gibt.

Das obige ist der detaillierte Inhalt vonWarum führt das Binden von Arrays an die IN-Klausel von PDO zu falschen Ergebnissen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage