Heim > Backend-Entwicklung > PHP-Tutorial > Warum gibt meine MySQLi-Abfrage nur eine Zeile zurück, wenn ich mehrere erwarte?

Warum gibt meine MySQLi-Abfrage nur eine Zeile zurück, wenn ich mehrere erwarte?

Mary-Kate Olsen
Freigeben: 2024-12-06 10:32:11
Original
385 Leute haben es durchsucht

Why is My MySQLi Query Only Returning One Row When I Expect Multiple?

Identifizieren der Grundursache dafür, dass eine MySQLi-Abfrage nur eine Zeile abruft

Wenn Sie mit dem Problem konfrontiert sind, dass eine MySQLi-Abfrage nur eine Zeile zurückgibt, obwohl mehrere Zeilen erwartet werden , ist es wichtig, den beteiligten Code zu untersuchen. Im bereitgestellten Fall zielt die Abfrage darauf ab, Daten aus den Tabellen sb_buddies und sb_users abzurufen.

Der Code wählt Spalten aus beiden Tabellen aus und verknüpft sie basierend auf dem Feld buddy_requester_id. Die folgende Zeile versucht jedoch, mit $request_list_result->fetch_array() nur eine einzelne Zeile abzurufen.

Lösung: Verwendung von fetch_all() zum Abrufen mehrerer Zeilen

Um mehrere Zeilen abzurufen, muss fetch_all() verwendet werden. Methode:

$request_list_result = $mysqli->query("
SELECT buddy_requester_id, buddy_reciepient_id, user_id, user_fullname FROM sb_buddies
JOIN sb_users ON buddy_requester_id=user_id
WHERE buddy_status='0' AND buddy_reciepient_id='". get_uid() ."'");

$request_list_rows = $request_list_result->fetch_all();

echo $request_list_rows[0]['user_fullname'];
Nach dem Login kopieren

Erklärung des Unterschieds

  • fetch_array() gibt eine einzelne Zeile als assoziatives Array zurück, wobei Spaltennamen als Schlüssel dienen.
  • fetch_all() gibt alle Zeilen als Array assoziativer Arrays zurück, die jeweils ein einzelnes darstellen Zeile.

Durch die Verwendung von fetch_all() kann der Code nun auf die Daten für alle übereinstimmenden Zeilen zugreifen, wodurch das Problem gelöst wird, nur eine Zeile zu erhalten.

Das obige ist der detaillierte Inhalt vonWarum gibt meine MySQLi-Abfrage nur eine Zeile zurück, wenn ich mehrere erwarte?. 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