Vorbereitete MySQL-Anweisungen mit variierender Variablenliste
Das Vorbereiten von MySQL-Anweisungen mit einer variablen Anzahl von Argumenten kann eine Herausforderung sein. Ein Szenario, in dem dies auftritt, ist eine IN-Klausel, die bei jeder Ausführung eine unterschiedliche Anzahl von IDs akzeptiert.
Mögliche Lösung 1: Dummy-Werte
Eine mögliche Lösung ist das Erstellen eine vorbereitete Anweisung, die eine feste Anzahl von Variablen akzeptiert, z. B. 100. Für die Ausführung mit weniger Werten werden Dummy-Werte hinzugefügt, um die verbleibenden Parameter zu füllen und sicherzustellen, dass sie vorhanden sind sind in der Tabelle nicht vorhanden. Dieser Ansatz erfordert jedoch mehrere Aufrufe für mehr als 100 Werte.
Mögliche Lösung 2: Dynamisches Generieren der IN-Klausel
Eine andere Möglichkeit besteht darin, die IN-Klausel dynamisch zu generieren Ausführungszeit. Indem wir die Funktion implode() verwenden, um eine Liste von Fragezeichen zu verketten, können wir die Klausel basierend auf der Anzahl der Parameter erstellen. Die resultierende Zeichenfolge wird verwendet, um eine vorbereitete Anweisung zu erstellen.
Alternative Lösung 1: Temporäre Tabelle
Eine alternative Lösung besteht darin, eine temporäre Tabelle zu erstellen und jeden Parameter in die einzufügen Tisch. Die Zieltabelle kann dann zum Filtern mit der temporären Tabelle verknüpft werden.
Alternative Lösung 2: Verkettete Anweisung
Eine übersichtliche Alternative besteht darin, die dynamisch generierte IN-Klausel direkt zu verketten in die vorbereitete Anweisungszeichenfolge ein, wodurch die vereinfacht wird Code.
Empfehlung
Die beste Lösung hängt vom spezifischen Kontext ab. Bei größeren Listen ist der Ansatz mit temporären Tabellen möglicherweise effizienter. Für kleinere Listen ist die dynamisch generierte IN-Klausel eine praktische Option. Die Implementierung der richtigen Parameterbindung ist entscheidend, um SQL-Injection zu verhindern.
Das obige ist der detaillierte Inhalt vonWie gehe ich mit variablen Argumentlisten in von MySQL vorbereiteten Anweisungen um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!