「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > MySQLi クエリが複数行を期待しているのに 1 行しか返さないのはなぜですか?

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

2024 年 11 月 18 日に公開
ブラウズ:616

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() を使用して複数の行を取得します

To複数の行を取得するには、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() はすべての行を連想配列の配列として返します。それぞれが 1 つの行を表します。

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

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3