개발자 Q&A

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

2025.05.20 14:34

PDO::commit 관련 질문

목록
  • 코딩테스트러버 1일 전 2025.05.20 14:34
  • 5
    1
저는 PDO::commit을 사용하여 데이터베이스 트랜잭션을 커밋하는 방법에 대해 궁금합니다.

저는 PDO::commit을 사용하여 데이터베이스 트랜잭션을 커밋할 때, commit이 실패하는 상황에서 rollback을 자동으로 호출하는 방법을 알고 싶습니다.

예를 들어, insert 문이 실패하는 경우, 이전에 insert 한 데이터를 rollback 하여 원래 상태로 되돌리기 원합니다.

PDO::commit을 사용하여 데이터베이스 트랜잭션을 커밋하는 방법에 대해 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    PDO::commit을 사용하여 데이터베이스 트랜잭션을 커밋하는 방법은 다음과 같습니다.

    1. PDO::beginTransaction() 메소드를 사용하여 트랜잭션을 시작합니다.
    2. 트랜잭션 내에서 데이터베이스 쿼리를 실행합니다.
    3. PDO::commit() 메소드를 사용하여 트랜잭션을 커밋합니다.
    4. 커밋이 실패하는 경우, PDO::rollBack() 메소드를 사용하여 이전 상태로 되돌립니다.

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

    #hostingforum.kr
    php
    
    $pdo = new PDO('mysql:host=localhost;dbname=mydb', 'username', 'password');
    
    
    
    $pdo->beginTransaction();
    
    
    
    try {
    
        $pdo->exec('INSERT INTO mytable (name, age) VALUES ("John", 30)');
    
        $pdo->exec('INSERT INTO mytable (name, age) VALUES ("Jane", 25)');
    
        $pdo->commit();
    
    } catch (PDOException $e) {
    
        $pdo->rollBack();
    
        echo "트랜잭션 커밋 실패: " . $e->getMessage();
    
    }
    
    


    이 코드에서는 PDO::beginTransaction() 메소드를 사용하여 트랜잭션을 시작하고, 두 개의 INSERT 문을 실행합니다. 커밋이 실패하는 경우, PDO::rollBack() 메소드를 사용하여 이전 상태로 되돌립니다.

    2025-05-20 14:35

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

검색

게시물 검색