ホームページ >バックエンド開発 >PHPチュートリアル >MySQLi クエリが 1 行だけを返すのはなぜですか?

MySQLi クエリが 1 行だけを返すのはなぜですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-14 09:48:02413ブラウズ

Why is My MySQLi Query Returning Only One Row?

1 行のみを返す MySQLi クエリのトラブルシューティング

この問題は、MySQLi クエリが期待どおりに複数の行ではなく 1 つの行のみをフェッチする場合に発生します。この問題は、ユーザーが一度に 1 行のみをフェッチする mysqli_result::fetch_array を使用してデータを取得するときに発生します。

これを解決するには、コードで代わりに mysqli_result::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();

foreach ($request_list as $request_list_row) {
    echo $request_list_row['user_fullname'];
}

この変更により、すべての行が返されるようになります。 MySQLi クエリが取得されて表示されます。

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

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。