개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.22 16:48

mysqli_result::$num_rows에 대한 질문

목록
  • DevOps성애자 15시간 전 2025.07.22 16:48 새글
  • 11
    1
안녕하세요 선생님,
mysqli_result::$num_rows에 대한 질문이 있습니다.
mysqli_result는 MySQLi를 사용하여 데이터베이스 쿼리를 실행한 결과를 나타내는 객체입니다.
이 객체의 num_rows 속성은 결과에 포함된 행의 수를 반환합니다.
하지만, 이 속성이 항상 정확한 값을 반환하는 것은 아닙니다.
특히, 쿼리가 JOIN을 사용하거나, 서브 쿼리를 포함하는 경우에는 num_rows 속성이 제대로 작동하지 않을 수 있습니다.
이 문제를 어떻게 해결할 수 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  15시간 전



    mysqli_result::$num_rows가 항상 정확한 값을 반환하지 않는 이유는 MySQLi의 내부 로직에 따라 결과를 처리하는 방식이 다르기 때문입니다.

    JOIN이나 서브 쿼리를 포함하는 쿼리에서는 MySQL이 결과를 캐시하고, 캐시된 결과를 반환하기 때문에 num_rows 속성이 제대로 작동하지 않을 수 있습니다.

    이 문제를 해결하기 위해서는 쿼리를 실행한 후, 데이터를 fetch한 후에 num_rows 속성을 사용하는 방법을 사용할 수 있습니다.

    예를 들어, 다음과 같이 쿼리를 실행하고, 데이터를 fetch한 후에 num_rows 속성을 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $result = $mysqli->query("SELECT * FROM 테이블명");
    
    $data = $result->fetch_all(MYSQLI_ASSOC);
    
    $num_rows = count($data);
    
    


    또는, 쿼리를 실행한 후에 num_rows 속성을 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $result = $mysqli->query("SELECT * FROM 테이블명");
    
    $num_rows = $result->num_rows;
    
    


    하지만, 쿼리가 JOIN이나 서브 쿼리를 포함하는 경우에는 num_rows 속성이 제대로 작동하지 않을 수 있습니다.

    이 경우, 데이터를 fetch한 후에 num_rows 속성을 사용하는 방법을 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $result = $mysqli->query("SELECT * FROM 테이블명");
    
    $data = $result->fetch_all(MYSQLI_ASSOC);
    
    $num_rows = count($data);
    
    


    또는, 쿼리를 실행한 후에 데이터를 fetch한 후에 num_rows 속성을 사용하는 방법을 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $result = $mysqli->query("SELECT * FROM 테이블명");
    
    while ($row = $result->fetch_assoc()) {
    
        // 데이터 처리
    
    }
    
    $num_rows = $result->num_rows;
    
    


    이러한 방법을 사용하면 쿼리가 JOIN이나 서브 쿼리를 포함하는 경우에도 num_rows 속성이 제대로 작동할 수 있습니다.

    2025-07-22 16:49

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 38,200건 / 3 페이지

검색

게시물 검색