개발자 Q&A

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

2025.08.11 05:26

Session::rollback에 대한 질문

목록
  • 디자인패턴마스터 21시간 전 2025.08.11 05:26 새글
  • 8
    1
제가 recently MySQL에서 Session::rollback을 사용하여 트랜잭션을 롤백하려고 합니다. 하지만 Session::rollback이 정상적으로 작동하지 않습니다.

트랜잭션을 시작하고 rollback을 호출했을 때, 데이터베이스에 변경된 내용이 롤백되지 않고 이전 상태로 돌아가지 않습니다.

이 문제가 발생하는 이유는 무엇이며, 어떻게 해결할 수 있는지 알려주세요.

그리고 rollback이 실패하는 경우, 어떤 오류 메시지를 출력할 수 있는지 알려주세요.

아래는 코드 예시입니다.

php

$conn = new mysqli($servername, $username, $password, $dbname);



// 트랜잭션 시작

$conn->autocommit(false);



// 데이터 변경

$conn->query("UPDATE users SET name = 'John' WHERE id = 1");



// rollback 호출

$conn->rollback();



// autocommit 재설정

$conn->autocommit(true);



위 코드에서 rollback이 정상적으로 작동하지 않습니다.

제가 사용한 버전은 MySQL 8.0.21입니다.

위와 같은 문제를 겪고 계신다면, 어떻게 해결할 수 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  21시간 전



    Session::rollback은 MySQL에서 트랜잭션을 롤백하는 데 사용되는 메소드입니다. 하지만, 트랜잭션을 롤백하지 못하는 문제가 발생할 수 있습니다.

    이 문제가 발생하는 이유는 MySQL의 autocommit 모드가 활성화된 상태에서 트랜잭션을 시작한 경우입니다. autocommit 모드는 각 쿼리가 자동으로 커밋되는 모드입니다. 트랜잭션을 시작하기 위해서는 autocommit 모드를 false로 설정해야 합니다.

    트랜잭션을 시작하고 rollback을 호출했을 때, 데이터베이스에 변경된 내용이 롤백되지 않고 이전 상태로 돌아가지 않는다면, 다음을 확인하세요.

    1. autocommit 모드가 활성화되어 있는지 확인하세요. autocommit 모드는 false로 설정되어야 트랜잭션을 시작할 수 있습니다.
    2. 트랜잭션을 시작한 쿼리가 커밋되지 않은 상태에서 rollback을 호출한 경우, 데이터베이스에 변경된 내용이 롤백되지 않을 수 있습니다.
    3. rollback을 호출한 후 autocommit 모드를 재설정한 경우, 데이터베이스에 변경된 내용이 롤백되지 않을 수 있습니다.

    rollback이 실패하는 경우, 오류 메시지를 출력할 수 있는지 알려드리겠습니다. MySQL의 rollback 메소드는 오류 메시지를 출력하지 않습니다. 하지만, 에러가 발생한 경우, MySQL의 error 메시지를 출력할 수 있습니다.

    위와 같은 문제를 겪고 계신다면, 다음을 확인하세요.

    1. autocommit 모드를 false로 설정하여 트랜잭션을 시작하세요.
    2. 트랜잭션을 시작한 쿼리가 커밋되지 않은 상태에서 rollback을 호출하세요.
    3. rollback을 호출한 후 autocommit 모드를 재설정하지 마세요.

    위 코드에서 rollback이 정상적으로 작동하지 않는다면, 다음을 확인하세요.

    #hostingforum.kr
    php
    
    $conn = new mysqli($servername, $username, $password, $dbname);
    
    
    
    // autocommit 모드를 false로 설정하여 트랜잭션을 시작하세요.
    
    $conn->autocommit(false);
    
    
    
    // 데이터 변경
    
    $conn->query("UPDATE users SET name = 'John' WHERE id = 1");
    
    
    
    // rollback을 호출하세요.
    
    $conn->rollback();
    
    
    
    // autocommit 모드를 재설정하지 마세요.
    
    


    위 코드에서 rollback이 정상적으로 작동하지 않는다면, MySQL의 버전을 확인하세요. MySQL 8.0.21 버전에서는 autocommit 모드가 기본적으로 활성화되어 있습니다. 따라서, autocommit 모드를 false로 설정하여 트랜잭션을 시작해야 합니다.

    2025-08-11 05:27

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

검색

게시물 검색