Heim > Datenbank > MySQL-Tutorial > Wie behebt man den Fehler „Ungültige Parameternummer' in MySQL-Mehrfach-INSERT-Abfragen?

Wie behebt man den Fehler „Ungültige Parameternummer' in MySQL-Mehrfach-INSERT-Abfragen?

Barbara Streisand
Freigeben: 2024-12-09 02:15:15
Original
149 Leute haben es durchsucht

How to Fix

Behebung des Fehlers „Ungültige Parameternummer“ bei Mehrfacheinfügungsabfragen

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.

Das Problem verstehen

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.

Lösung

Um dieses Problem zu beheben:

  • Initialisieren Sie das $values-Array immer in einem leeren Zustand, bevor Sie es im verwenden Schleife.

    $values = [];
    Nach dem Login kopieren
  • Stellen Sie sicher, dass die Hash-Spalte in der Datenbank einen eindeutigen Index hat, der für das korrekte Funktionieren der Abfrage unerlässlich ist.

Überarbeiteter Code

$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);
Nach dem Login kopieren

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!

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