개발자 Q&A

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

2025.03.20 02:37

Session::commit 관련 질문

목록
  • Android개발광 1일 전 2025.03.20 02:37
  • 3
    1
제가 학습 중인 Topic은 Database Transaction입니다.
단순하게 설명해드리면, Transaction은 데이터베이스 작업을 묶어 하나의 작업 단위로 처리하는 것입니다.

여기서 Session::commit은 Transaction이 성공적으로 완료된 경우에 Commit Operation을 수행하여 데이터베이스에 변경된 데이터를 반영하는 것입니다.

제가 이해 못 하는 부분은, 만약 Transaction이 성공적으로 완료되지 않고 Rollback Operation을 수행해야 하는 상황에서 Session::commit을 호출하면 어떻게 될까요?

혹시 Rollback Operation이 자동으로 진행되는지, 아니면 에러가 발생하는지 궁금합니다.

혹시 해결 방법이 있다면 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    Session::commit을 호출하면 Transaction이 성공적으로 완료된 경우에 Commit Operation을 수행하여 데이터베이스에 변경된 데이터를 반영합니다.

    그러나 만약 Transaction이 성공적으로 완료되지 않고 Rollback Operation을 수행해야 하는 상황에서 Session::commit을 호출하면 에러가 발생합니다.

    이유는 Transaction이 이미 Rollback 상태이기 때문에 Commit Operation을 수행할 수 없기 때문입니다.

    Rollback Operation이 자동으로 진행되는 것은 아니며, 에러가 발생하는 것입니다.

    해결 방법은 Transaction이 Rollback 상태이기 전에 Commit Operation을 수행하거나, Transaction을 롤백하고 다시 시작하는 것입니다.

    예를 들어, PHP에서 Session::commit을 호출하기 전에 Transaction이 Rollback 상태인지 확인하는 코드를 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    if ($session->isTransactionRollbacked()) {
    
        // Transaction이 Rollback 상태이므로 에러를 발생시킵니다.
    
        throw new Exception('Transaction is already rolled back.');
    
    } else {
    
        // Transaction이 성공적으로 완료되었습니다. Commit Operation을 수행합니다.
    
        $session->commit();
    
    }
    
    

    2025-03-20 02:38

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

검색

게시물 검색