개발자 Q&A

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

2025.07.30 22:43

mysqli::close() 함수 사용 시 문제 발생

목록
  • 루트권한 1일 전 2025.07.30 22:43
  • 4
    1
제가 사용하고 있는 PHP 코드에서 mysqli::close() 함수를 사용하여 데이터베이스 연결을 종료하고자 합니다. 그러나 연결을 종료한 후에도 데이터베이스에 접근이 가능한 이유가 무엇인지 궁금합니다.

제가 현재 사용하는 코드는 다음과 같습니다.
php

$mysqli = new mysqli("localhost", "root", "password", "database");



// 쿼리 실행 후 결과 처리

$result = $mysqli->query("SELECT * FROM table");



// 결과 처리 후 mysqli::close() 함수 호출

$mysqli->close();


이러한 코드를 사용하여 연결을 종료한 후에도 데이터베이스에 접근이 가능한 이유가 무엇인지 알려주시 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    mysqli::close() 함수를 호출하여 데이터베이스 연결을 종료한 후에도 데이터베이스에 접근이 가능한 이유는 다음과 같습니다.

    mysqli::close() 함수는 현재 연결된 데이터베이스 연결을 종료하는 함수입니다. 그러나 PHP는 연결된 데이터베이스 연결을 캐시에 저장할 수 있습니다. 이 캐시는 PHP가 실행되는 동안 유지됩니다. 따라서 mysqli::close() 함수를 호출하여 연결을 종료한 후에도 데이터베이스에 접근이 가능합니다.

    이러한 캐시를 제거하려면 PHP의 세션을 종료하거나 PHP를 종료하는 방법이 있습니다. 또는 mysqli::close() 함수를 호출하기 전에 mysqli::real_query() 함수를 호출하여 데이터베이스 연결을 종료하고 캐시를 삭제할 수 있습니다.

    mysqli::real_query() 함수를 호출하여 데이터베이스 연결을 종료하는 코드는 다음과 같습니다.

    #hostingforum.kr
    php
    
    $mysqli->real_query("SET AUTOCOMMIT = 1");
    
    $mysqli->close();
    
    


    이러한 코드를 사용하여 데이터베이스 연결을 종료하고 캐시를 삭제할 수 있습니다.

    2025-07-30 22:44

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

검색

게시물 검색