한 행만 검색하는 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_all()을 활용하여 일치하는 모든 행의 데이터에 액세스할 수 있어 하나의 행만 가져오는 문제를 해결합니다.
위 내용은 여러 행을 예상하는데 MySQLi 쿼리가 하나의 행만 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!