Gebundene Parameter mehrfach verwenden
Bei der Datenbankprogrammierung ist die Verwendung gebundener Parameter entscheidend, um SQL-Injection-Angriffe zu verhindern. Entwickler stoßen jedoch häufig auf ein Problem, wenn sie versuchen, denselben Parameter mehrmals in einer vorbereiteten Anweisung zu verwenden.
Ursprüngliche Problemstellung
Der ursprüngliche Beitrag beschreibt ein Szenario, in dem a Der Benutzer möchte eine Suchmaschine implementieren, die UNION SELECT verwendet, um Daten aus verschiedenen Tabellen mit jeweils unterschiedlichen Suchkriterien abzurufen. Die Abfrage enthält mehrere Instanzen eines „:term“-Parameters, der an eine vorbereitete Anweisung gebunden wird.
Lösung: Benutzerdefinierte Variablen
Die bereitgestellte Lösung bietet Ein alternativer Ansatz zur mehrfachen Verwendung gebundener Parameter. Durch die Verwendung benutzerdefinierter MySQL-Variablen können Entwickler ihren Code vereinfachen und die Lesbarkeit verbessern:
Beispielcode
$sql = "SET @term = :term"; $stmt = $dbh->prepare($sql); $stmt->bindValue(":term", "%$term%", PDO::PARAM_STR); $stmt->execute(); $sql = "SELECT ... FROM table WHERE name LIKE @term OR number LIKE @term"; $stmt = $dbh->prepare($sql); $stmt->execute(); $stmt->fetchAll();
Vorteile
Nachteile
Das obige ist der detaillierte Inhalt vonWie kann ich gebundene Parameter in einer vorbereiteten Anweisung mehrmals wiederverwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!