Heim >Backend-Entwicklung >PHP-Tutorial >Warum erhalte ich in MySQLi beim Abrufen hierarchischer Daten die Fehlermeldung „Befehle nicht synchron'?

Warum erhalte ich in MySQLi beim Abrufen hierarchischer Daten die Fehlermeldung „Befehle nicht synchron'?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-06 09:31:121022Durchsuche

Why Am I Getting a

Fehler „MySQLi-Befehle nicht synchron“ beim Hierarchieabruf

Beim Versuch, mehrere MySQLi auszuführen, kann der Fehler „Befehle nicht synchron“ auftreten Abfragen, insbesondere beim Abrufen hierarchischer Daten. Dieser Artikel befasst sich mit dem Problem, erklärt seine Ursache und bietet mögliche Lösungen.

Ursache

Der MySQL-Client schränkt die Ausführung neuer Abfragen ein, während Zeilen nicht von einem abgerufen werden laufende Abfrage. Dieser Fehler ist auf das Protokoll des Clients zurückzuführen, das sicherstellt, dass alle Zeilen nacheinander abgerufen werden, bevor mit neuen Abfragen fortgefahren wird.

Mögliche Lösungen

Um dieses Problem zu beheben, stehen mehrere Optionen zur Verfügung :

1. Mit mysqli_store_result()

Diese Methode ruft alle Zeilen aus der äußeren Abfrage vorab in einen Client-Puffer ab. Der MySQL-Server bestätigt den vollständigen Abruf der Ergebnisse, sodass nachfolgende Abfragen frei ausgeführt werden können.

2. Mit mysqli_result::fetch_all()

Ähnlich wie mysqli_store_result() ruft diese Methode die gesamte Ergebnismenge als PHP-Array ab und ermöglicht so ein effizientes Schleifen und Abrufen von Daten.

3. Verwendung von mysqli_multi_query() für gespeicherte Prozeduren

Gespeicherte Prozeduren können möglicherweise mehrere Ergebnismengen zurückgeben, von denen jede ihre eigenen Zeilen enthält. mysqli_multi_query() sollte verwendet werden, um diese Ergebnismengen zu durchlaufen, sie nacheinander zu verarbeiten und das MySQL-Protokoll einzuhalten.

Alternative Datenspeicherung

Um die Nachteile von verschachtelten zu vermeiden Bei Abfragen im hierarchischen Datenabruf sollten Sie eine Umstrukturierung der Daten für eine einfachere Abfrage in Betracht ziehen. Techniken wie Adjazenzlisten oder verschachtelte Mengen können Hierarchien erheblich vereinfachen.

Benutzerdefinierter Hack für CodeIgnitor 3.0.3

Für Benutzer von CodeIgnitor 3.0.3 besteht eine Problemumgehung darin, die Zeile zu ändern 262 der Datei mysqli_driver.php. Durch Hinzufügen von @mysqli_next_result() zur Methode _execute() kann der Fehler „Befehl nicht synchron“ gemildert werden.

Das obige ist der detaillierte Inhalt vonWarum erhalte ich in MySQLi beim Abrufen hierarchischer Daten die Fehlermeldung „Befehle nicht synchron'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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