한 행만 검색하는 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_all()을 활용하여 일치하는 모든 행의 데이터에 액세스할 수 있으므로 행 하나만 가져오는 문제를 해결할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3