개발자 Q&A

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

2025.06.20 18:22

mysqli::autocommit에 대한 질문

목록
  • 엔지니어링고수 1일 전 2025.06.20 18:22
  • 4
    1
저는 mysqli::autocommit에 대해 이해가 되지 않는 부분이 있습니다.

제가 이해한 바에 따르면, mysqli::autocommit은 MySQL 쿼리를 자동으로 커밋하는 기능이 맞습니다. 하지만, 이 기능을 사용하면 어떤 문제가 발생할 수 있을까요?

또한, mysqli::autocommit을 사용하지 않고 커밋을 수동으로 처리하는 방법도 궁금합니다.

위의 두 가지 질문에 대해 답변해주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    mysqli::autocommit은 MySQL 쿼리를 자동으로 커밋하는 기능입니다. 이 기능을 사용하면, 쿼리를 실행할 때마다 자동으로 커밋이 발생하므로, 트랜잭션을 관리하는 기능을 사용할 수 없습니다.

    이러한 문제로 인해, 데이터베이스의 일관성을 유지하기 어려울 수 있습니다. 예를 들어, 쿼리를 실행하는 도중 오류가 발생할 경우, 이전에 실행한 쿼리들이 자동으로 커밋되어 데이터베이스의 상태가 손상될 수 있습니다.

    mysqli::autocommit을 사용하지 않고 커밋을 수동으로 처리하는 방법은, mysqli::commit() 함수를 사용하는 것입니다.

    예를 들어, 다음과 같은 코드를 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("호스트", "사용자", "비밀번호", "데이터베이스");
    
    
    
    // 쿼리를 실행합니다.
    
    $mysqli->query("INSERT INTO 테이블 (컬럼1, 컬럼2) VALUES ('값1', '값2')");
    
    
    
    // 커밋을 수동으로 처리합니다.
    
    $mysqli->commit();
    
    


    또한, mysqli::autocommit을 사용하지 않고 롤백을 수동으로 처리하는 방법은, mysqli::rollback() 함수를 사용하는 것입니다.

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("호스트", "사용자", "비밀번호", "데이터베이스");
    
    
    
    // 쿼리를 실행합니다.
    
    $mysqli->query("INSERT INTO 테이블 (컬럼1, 컬럼2) VALUES ('값1', '값2')");
    
    
    
    // 롤백을 수동으로 처리합니다.
    
    $mysqli->rollback();
    
    

    2025-06-20 18:23

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

검색

게시물 검색