개발자 Q&A

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

2025.06.10 17:03

PDO::commit 사용 시 질문

목록
  • Bootstrap고수 오래 전 2025.06.10 17:03 인기
  • 108
    1
안녕하세요 선생님.
PHP의 PDO를 사용하여 데이터베이스 연동을 할 때,
데이터를 삽입하거나 업데이트한 후에는 데이터베이스의 변경 사항을 저장하기 위해
PDO::commit() 함수를 사용해야 하는데요.
이때, PDO::commit() 함수를 호출하지 않으면 데이터베이스에 저장되지 않습니다.
하지만, PDO::commit() 함수를 호출할 때 특정한 조건이나 상황이 발생할 수 있습니다.
예를 들어, 데이터베이스에 데이터를 삽입하거나 업데이트하는 중에 에러가 발생하면
PDO::commit() 함수를 호출하지 않고 에러를 처리해야 합니다.
이러한 경우 PDO::commit() 함수를 호출하지 않으면 데이터베이스에 저장되지 않습니다.
이러한 문제를 해결하기 위해 PDO::commit() 함수를 호출하는 시점을 어떻게 결정해야 하는지
궁금합니다.

    댓글목록

    profile_image
    나우호스팅  오래 전



    PDO::commit() 함수를 호출하는 시점을 결정하는 방법은 다음과 같습니다.

    1. 트랜잭션의 시작과 끝: PDO::commit() 함수를 호출하기 전에는 트랜잭션을 시작해야 합니다. 트랜잭션의 시작과 끝을 명확하게 구분하여 PDO::commit() 함수를 호출할 수 있습니다.

    2. 에러 처리: 데이터베이스 연동 중 에러가 발생하면 PDO::commit() 함수를 호출하지 않고 에러를 처리해야 합니다. 에러 처리를 위한 try-catch 블록을 사용하여 PDO::commit() 함수를 호출하지 않도록 할 수 있습니다.

    3. 트랜잭션의 롤백: 데이터베이스 연동 중 에러가 발생하면 PDO::rollBack() 함수를 호출하여 트랜잭션을 롤백할 수 있습니다. PDO::rollBack() 함수를 호출하면 PDO::commit() 함수를 호출하지 않습니다.

    4. 자동 커밋: PDO::setAttribute() 함수를 사용하여 PDO::ATTR_AUTOCOMMIT 옵션을 false로 설정하여 자동 커밋을 비활성화할 수 있습니다. 자동 커밋이 비활성화되면 PDO::commit() 함수를 호출하지 않습니다.

    5. 트랜잭션의 커밋: PDO::commit() 함수를 호출하기 전에는 트랜잭션을 커밋해야 합니다. 트랜잭션의 커밋을 명확하게 구분하여 PDO::commit() 함수를 호출할 수 있습니다.

    예를 들어, 다음과 같이 try-catch 블록을 사용하여 PDO::commit() 함수를 호출하지 않도록 할 수 있습니다.

    #hostingforum.kr
    php
    
    try {
    
        // 데이터베이스 연동
    
        $stmt = $pdo->prepare("INSERT INTO 테이블명 (컬럼명) VALUES (:값)");
    
        $stmt->execute(array(":값" => "값"));
    
        
    
        // PDO::commit() 함수를 호출하지 않습니다.
    
    } catch (PDOException $e) {
    
        // 에러 처리
    
        echo "에러 발생: " . $e->getMessage();
    
        
    
        // PDO::rollBack() 함수를 호출하여 트랜잭션을 롤백합니다.
    
        $pdo->rollBack();
    
    }
    
    


    또는, 다음과 같이 PDO::setAttribute() 함수를 사용하여 PDO::ATTR_AUTOCOMMIT 옵션을 false로 설정하여 자동 커밋을 비활성화할 수 있습니다.

    #hostingforum.kr
    php
    
    $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, false);
    
    
    
    // 데이터베이스 연동
    
    $stmt = $pdo->prepare("INSERT INTO 테이블명 (컬럼명) VALUES (:값)");
    
    $stmt->execute(array(":값" => "값"));
    
    
    
    // PDO::commit() 함수를 호출하지 않습니다.
    
    $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, true);
    
    

    2025-06-10 17:04

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

검색

게시물 검색