>백엔드 개발 >PHP 튜토리얼 >여러 행을 예상하는데 MySQLi 쿼리가 하나의 행만 반환하는 이유는 무엇입니까?

여러 행을 예상하는데 MySQLi 쿼리가 하나의 행만 반환하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-06 10:32:11357검색

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

한 행만 검색하는 MySQLi 쿼리의 근본 원인 식별

MySQLi 쿼리에서 여러 행을 예상했음에도 불구하고 한 행만 반환하는 문제에 직면한 경우 , 관련된 코드를 검사하는 것이 중요합니다. 제공된 경우 쿼리의 목표는 sb_buddies 및 sb_users 테이블에서 데이터를 검색하는 것입니다.

코드는 두 테이블 모두에서 열을 선택하고 buddy_requester_id 필드를 기반으로 이들을 조인합니다. 그러나 후속 행에서는 $request_list_result->fetch_array()를 사용하여 단일 행만 가져오려고 시도합니다.

해결책: 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()은 모든 행을 연관 배열의 배열로 반환하며, 각 행은 단일 행을 나타냅니다.

이제 코드는 fetch_all()을 활용하여 일치하는 모든 행의 데이터에 액세스할 수 있어 하나의 행만 가져오는 문제를 해결합니다.

위 내용은 여러 행을 예상하는데 MySQLi 쿼리가 하나의 행만 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.