개발자 Q&A

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

2025.03.08 00:43

SQLSRV_num_rows 함수 사용시 질문

목록
  • Azure마스터 12일 전 2025.03.08 00:43
  • 7
    1
저는 php에서 sqlsrv_num_rows 함수를 사용하여 레코드의 총 개수를 구하려고 하는데요,
이 함수를 사용할 때는 php파일의 위치와 db 연결의 위치가 동일해야 하는 것 같은데요,
아래와 같은 코드를 작성하였는데 오류가 발생합니다.

php

<?php

   $serverName = "localhost";

   $connectionInfo = array("Database"=>"mydb", "UID"=>"myuser", "PWD"=>"mypassword");

   $conn = sqlsrv_connect($serverName, $connectionInfo);

   if ($conn === false) {

       echo "연결 실패";

       exit;

   }

   $sql = "SELECT * FROM mytable";

   $stmt = sqlsrv_query($conn, $sql);

   $count = sqlsrv_num_rows($stmt);

   sqlsrv_close($conn);

   echo $count;

?>


위의 코드에서 sqlsrv_num_rows 함수를 사용하여 레코드의 총 개수를 구하려고 하는데,
오류가 발생합니다. 오류 메시지가 "sqlsrv_num_rows() expects parameter 1 to be resource, bool given"입니다.
이 오류는 무엇을 의미하며, 어떻게 해결할 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  12일 전



    sqlsrv_num_rows 함수는 SQLSRV 드라이버에서 사용할 수 있는 함수입니다. 이 함수는 SQLSRV 드라이버가 지원하는 결과 집합의 행 수를 반환합니다.

    위의 오류 메시지 \"sqlsrv_num_rows() expects parameter 1 to be resource, bool given\"은 sqlsrv_num_rows 함수가 결과 집합을 반환하지 못했기 때문에 발생하는 오류입니다.

    이 오류는 sqlsrv_query 함수가 결과 집합을 반환하지 못했기 때문에 발생합니다. sqlsrv_query 함수는 SQL 문을 실행하고 결과 집합을 반환합니다. 만약 SQL 문이 실행되지 않거나 오류가 발생하면 sqlsrv_query 함수는 false를 반환합니다.

    위의 코드에서 sqlsrv_query 함수는 다음과 같이 수정되어야 합니다.

    #hostingforum.kr
    php
    
    $stmt = sqlsrv_query($conn, $sql);
    
    if ($stmt === false) {
    
        echo "SQL 문이 실행되지 않았습니다.";
    
        exit;
    
    }
    
    $count = sqlsrv_num_rows($stmt);
    
    


    이러한 수정을 통해 sqlsrv_query 함수가 결과 집합을 반환할 수 있도록 하며, sqlsrv_num_rows 함수가 결과 집합의 행 수를 반환할 수 있도록 합니다.

    2025-03-08 00:44

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

검색

게시물 검색