개발자 Q&A

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

2025.06.10 10:28

SQLSRV_num_rows 함수 이해를 부탁드립니다.

목록
  • 코드마스터 오래 전 2025.06.10 10:28 인기
  • 115
    1
저는 PHP에서 SQLSRV 연동을 공부하고 있습니다.
SQLSRV_num_rows 함수를 사용하여 레코드의 개수를 확인하려고 하는데,
다음과 같은 코드를 사용하였습니다.

php

$stmt = sqlsrv_query($conn, "SELECT * FROM 테이블명");

$num_rows = sqlsrv_num_rows($stmt);



그런데, 위 코드를 사용하여 레코드의 개수를 확인했을 때,
다음과 같은 결과가 나옵니다.

php

$num_rows = 0;



레코드가 실제로 있는 테이블에서도 레코드의 개수가 0으로 나옵니다.
이러한 문제가 발생하는 이유를 알고 싶습니다.
레코드의 개수를 확인하는 방법에 대해 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    SQLSRV_num_rows 함수는 SELECT 쿼리에서만 사용할 수 있습니다. INSERT, UPDATE, DELETE 쿼리에서는 사용할 수 없습니다.

    또한, SQLSRV_num_rows 함수는 쿼리 결과를 fetch하지 않은 상태에서 사용해야 합니다. fetch() 함수를 호출하면 결과를 가져오기 때문에 SQLSRV_num_rows 함수의 결과가 정확하지 않을 수 있습니다.

    따라서, SQLSRV_num_rows 함수를 사용하려면 다음과 같이 쿼리 결과를 fetch하지 않은 상태에서 사용해야 합니다.

    #hostingforum.kr
    php
    
    $stmt = sqlsrv_query($conn, "SELECT * FROM 테이블명");
    
    if ($stmt === false) {
    
        die('쿼리 실패: ' . print_r(sqlsrv_errors(), true));
    
    }
    
    
    
    $num_rows = sqlsrv_num_rows($stmt);
    
    


    이러한 방법으로 SQLSRV_num_rows 함수를 사용하면 레코드의 개수를 정확하게 확인할 수 있습니다.

    2025-06-10 10:29

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

검색

게시물 검색