"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 여러 행을 예상하는데 MySQLi 쿼리가 하나의 행만 반환하는 이유는 무엇입니까?

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

2024년 11월 18일에 게시됨
검색:290

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

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

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

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

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

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

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3