개발자 Q&A

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

2025.07.28 06:45

mysqli_result::free에 대한 질문

목록
  • 루트권한 5시간 전 2025.07.28 06:45 새글
  • 1
    1
제가 mysqli_result::free 함수를 사용하여 결과를 해제할 때, 왜 결과를 사용한 후에 free를 호출해야 하는지 이해가 가지 않습니다.

mysqli_result::free 함수를 호출하면, 내부적으로 어떤 작업을 수행하는지 간단하게 설명해주시면 감사하겠습니다.

또한, free를 호출하지 않고 결과를 사용했을 때, 어떤 문제가 발생하는지 알려주시면 좋을 것 같습니다.

    댓글목록

    profile_image
    나우호스팅  5시간 전



    mysqli_result::free 함수는 MySQLi extension에서 사용하는 결과 객체를 해제하는 함수입니다.

    이 함수를 호출하는 이유는 MySQLi extension에서 결과 객체를 사용한 후에 반드시 해제해야 하기 때문입니다.

    해제하지 않으면 MySQLi extension의 리소스가 계속해서 사용되어 메모리 누수 및 성능 저하가 발생할 수 있습니다.

    mysqli_result::free 함수는 내부적으로 MySQLi extension의 결과 객체를 해제하고, 메모리를 해제하는 작업을 수행합니다.

    해제하지 않은 결과 객체를 다시 사용하려고 하면, PHP에서 에러가 발생할 수 있습니다.

    따라서, 결과를 사용한 후에 반드시 mysqli_result::free 함수를 호출하여 결과 객체를 해제해야 합니다.

    예를 들어, 다음 코드는 결과를 사용한 후에 해제하지 않은 채로 다시 사용하려고 하므로, PHP에서 에러가 발생합니다.

    #hostingforum.kr
    php
    
    $result = $mysqli->query("SELECT * FROM 테이블");
    
    $data = $result->fetch_assoc();
    
    $result->free(); // 해제하지 않은 채로 다시 사용하려고 함
    
    $result->fetch_assoc(); // 에러 발생
    
    


    해제를 수행한 후의 예제는 다음과 같습니다.

    #hostingforum.kr
    php
    
    $result = $mysqli->query("SELECT * FROM 테이블");
    
    $data = $result->fetch_assoc();
    
    $result->free(); // 해제
    
    

    2025-07-28 06:47

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

검색

게시물 검색