개발자 Q&A

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

2025.06.14 03:39

SQLSRV_FREE_STMT 함수 사용에 대한 문의

목록
  • 네트워크마법사 오래 전 2025.06.14 03:39
  • 86
    1
제가 sqlsrv_free_stmt 함수를 사용하여 PHP에서 SQLSRV 연결을 해제할 때 아래와 같은 코드를 사용하고 있습니다.
php

$sql = "SELECT * FROM 테이블명";

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

// 쿼리 결과를 처리합니다.

sqlsrv_free_stmt($stmt);

sqlsrv_close($conn);


여기서 sqlsrv_free_stmt($stmt) 함수를 사용하여 $stmt 변수에 저장된 쿼리 결과를 해제하고 있습니다. 하지만 이 함수를 사용한 후에 sqlsrv_close($conn) 함수를 호출할 때 에러가 발생합니다.

이 문제가 발생하는 이유는 무엇이며, sqlsrv_free_stmt 함수를 사용한 후 sqlsrv_close 함수를 호출할 수 있는 방법을 알려주세요?

    댓글목록

    profile_image
    나우호스팅  오래 전



    SQLSRV_FREE_STMT 함수는 쿼리 결과를 해제하는 함수입니다. 이 함수를 호출한 후에 SQLSRV_CLOSE 함수를 호출하면 에러가 발생하는 이유는 SQLSRV_CLOSE 함수가 쿼리 결과를 해제하는 함수인 SQLSRV_FREE_STMT 함수를 호출하기 전에 쿼리 결과를 해제하지 않아 발생하는 오류입니다.

    해결 방법은 SQLSRV_CLOSE 함수를 호출하기 전에 SQLSRV_FREE_STMT 함수를 호출하여 쿼리 결과를 해제하는 것입니다.

    #hostingforum.kr
    php
    
    $sql = "SELECT * FROM 테이블명";
    
    $stmt = sqlsrv_query($conn, $sql);
    
    // 쿼리 결과를 처리합니다.
    
    // 쿼리 결과를 해제합니다.
    
    sqlsrv_free_stmt($stmt);
    
    // 연결을 종료합니다.
    
    sqlsrv_close($conn);
    
    


    또한, 쿼리 결과를 해제하지 않고 연결을 종료하면 에러가 발생할 수 있습니다. 따라서 쿼리 결과를 해제하는 함수인 SQLSRV_FREE_STMT 함수를 호출하여 쿼리 결과를 해제한 후에 SQLSRV_CLOSE 함수를 호출하여 연결을 종료하는 것이 좋습니다.

    2025-06-14 03:40

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

검색

게시물 검색