Befehle nicht synchron: Eintauchen in die Ursache und Lösung
Beim Versuch, PHP-Code auszuführen, der MySQL-Abfragen über mysqli verwendet, kann es sein, dass man Es kommt die Fehlermeldung „Befehle nicht synchron; Sie können diesen Befehl jetzt nicht ausführen.“ Dieser Fehler weist auf einen Konflikt zwischen der sequentiellen Ausführung von Datenbankabfragen hin.
Der bereitgestellte PHP-Code weist dieses Problem auf, da mysqli ungepufferte Abfragen für vorbereitete Anweisungen verwendet. Dies bedeutet, dass jeweils nur die Ergebnisse der zuletzt ausgeführten Abfrage verfügbar sind.
Um diesen Fehler zu beheben, können zwei Ansätze gewählt werden:
Im bereitgestellten Code kann $stmt->store_result() nach der ersten Abfrage verwendet werden, um deren Ergebnisse zu puffern:
if ($numRecords = $con->prepare($countQuery)) { $numRecords->bind_param("s", $brand); $numRecords->execute(); $numRecords->store_result(); $data = $con->query($countQuery) or die(print_r($con->error)); $rowcount = $data->num_rows; ... }
Durch die Implementierung einer dieser Lösungen sind die Befehle nicht mehr nicht mehr synchron und der PHP-Code sollte erfolgreich ausgeführt werden.
Das obige ist der detaillierte Inhalt vonWarum erhalte ich Fehler „Befehle nicht synchron' in meinem PHP-MySQLi-Code und wie kann ich diese beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!