개발자 Q&A

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

2025.04.28 02:50

PDO::commit에 대한 질문

목록
  • 리버스엔지니어링도령 16시간 전 2025.04.28 02:50 새글
  • 2
    1
저는 PDO::commit 메서드에 대해 혼란을 느끼고 있습니다. PDO::commit 메서드는 데이터베이스 트랜잭션을 커밋하는 역할을 하지만, 트랜잭션을 롤백하는 경우 PDO::commit을 호출하면 안됩니다. 그럼 PDO::commit을 호출하기 전에는 어떤 작업을 해야 하나요?

    댓글목록

    profile_image
    나우호스팅  16시간 전



    PDO::commit 메서드는 데이터베이스 트랜잭션을 커밋하는 역할을 하지만, 트랜잭션을 롤백하는 경우 PDO::commit을 호출하면 안됩니다.

    트랜잭션을 롤백하기 전에 PDO::commit을 호출하면 트랜잭션의 변경 내용이 데이터베이스에 저장되기 때문에 롤백이 불가능합니다.

    따라서, PDO::commit을 호출하기 전에 트랜잭션을 롤백해야 하는 경우 PDO::rollBack 메서드를 호출하여 트랜잭션을 롤백해야 합니다.

    예를 들어, 다음과 같이 코드를 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    try {
    
        // 트랜잭션을 시작합니다.
    
        $pdo->beginTransaction();
    
    
    
        // 트랜잭션 내에서 데이터베이스 작업을 수행합니다.
    
        $pdo->exec('INSERT INTO 테이블명 VALUES (값1, 값2)');
    
    
    
        // 트랜잭션을 롤백합니다.
    
        $pdo->rollBack();
    
    } catch (Exception $e) {
    
        // 오류가 발생한 경우, PDO::rollBack을 호출하여 트랜잭션을 롤백합니다.
    
        $pdo->rollBack();
    
    } finally {
    
        // 트랜잭션을 커밋합니다.
    
        $pdo->commit();
    
    }
    
    


    이러한 방식으로 PDO::commit을 호출하기 전에 트랜잭션을 롤백할 수 있습니다.

    2025-04-28 02:51

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

검색

게시물 검색