ホームページ > バックエンド開発 > PHPチュートリアル > MySQLi クエリが複数行を期待しているのに 1 行しか返さないのはなぜですか?

MySQLi クエリが複数行を期待しているのに 1 行しか返さないのはなぜですか?

Mary-Kate Olsen
リリース: 2024-12-06 10:32:11
オリジナル
383 人が閲覧しました

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

MySQLi クエリが 1 行だけを取得する根本原因の特定

MySQLi クエリが複数の行を期待しているにもかかわらず 1 行だけを返すという問題に直面した場合、関係するコードを調べることが重要です。指定されたケースでは、クエリは sb_buddies テーブルと sb_users テーブルからデータを取得することを目的としています。

コードは両方のテーブルから列を選択し、buddy_requester_id フィールドに基づいてそれらを結合します。ただし、後続の行は、$request_list_result->fetch_array() を使用して 1 つの行のみをフェッチしようとします。

解決策: fetch_all() を使用して複数の行を取得します

複数の行を取得するには、 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_rows = $request_list_result->fetch_all();

echo $request_list_rows[0]['user_fullname'];
ログイン後にコピー

違いの説明

  • fetch_array() は、列名がキーとして機能する単一行を連想配列として返します。
  • fetch_all() は、すべての行を連想配列の配列として返します。各行は単一の行を表します。 row.

fetch_all() を利用することで、コードは一致するすべての行のデータにアクセスできるようになり、1 行しか取得できない問題が解決されました。

以上がMySQLi クエリが複数行を期待しているのに 1 行しか返さないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート