Im bereitgestellten Code tritt der Fehler beim Ausführen einer Mehrfacheinfügungsabfrage aufgrund einer Parameterinkongruenz zwischen auf die eingefügten Werte und die erwartete Anzahl von Parametern in der Abfrage.
Der Code generiert ein Array von Platzhaltern ($values) basierend auf der Anzahl der Übereinstimmungen ($matches). Wenn jedoch bereits Inhalt im Array „$values“ vorhanden ist, kann es zu einer Diskrepanz in der Anzahl kommen, die den Fehler verursacht.
Um dieses Problem zu beheben:
Initialisieren Sie das $values-Array immer in einem leeren Zustand, bevor Sie es im verwenden Schleife.
$values = [];
$matches = array('1'); $count = count($matches); $values = []; for($i = 0; $i < $count; ++$i) { $values[] = '(?)'; } $sql = "INSERT INTO hashes (hash) VALUES " . implode(', ', $values) . " ON DUPLICATE KEY UPDATE hash=values(hash)"; $stmt = $dbh->prepare($sql); $data = $stmt->execute($matches);
Durch die Implementierung dieser Änderungen sollte der Code erfolgreich ausgeführt werden, ohne dass der Parameterkonfliktfehler auftritt.
Das obige ist der detaillierte Inhalt vonWie behebt man den Fehler „Ungültige Parameternummer' in MySQL-Mehrfach-INSERT-Abfragen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!