MySQLi Query Only Returns One Row
提供されたコードでは、作成者は MySQLi を使用してデータベースから複数の行をフェッチしようとしていますが、クエリは単一行のみを返します。これは、SQL クエリが phpMyAdmin で直接実行されると 2 行を返すことを確認しているにもかかわらずです。
問題
問題は、MySQLi からデータをフェッチするために使用されるメソッドにあります。結果オブジェクト。コードでは、結果セットの最初の行のみを取得する fetch_array() が使用されます。すべての行を取得するには、代わりに fetch_all() を使用する必要があります。
修正コード
$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 = $request_list_result->fetch_all(); // Now $request_list holds all rows in the result set
追加リソース
MySQLi 結果セットからのデータのフェッチの詳細については、次のリソースを参照してください:
以上がMySQLi クエリが 1 行しか返さないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。