개발자 Q&A

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

2025.05.11 18:22

Session::startTransaction 관련 질문

목록
  • 화이트해커연구가 1일 전 2025.05.11 18:22
  • 2
    1
저는 ORM을 사용하여 데이터베이스 트랜잭션을 관리하고 있으나, Session::startTransaction 메서드에 대한 이해가 부족합니다.

Session::startTransaction 메서드는 트랜잭션을 시작하는 데 사용되는 것인가요? 그리고 이 메서드를 호출한 후, 트랜잭션을 롤백하는 방법은 무엇인가요?

    댓글목록

    profile_image
    나우호스팅  1일 전



    Session::startTransaction 메서드는 트랜잭션을 시작하는 데 사용되는 메서드입니다. 이 메서드를 호출하면, 데이터베이스에서 트랜잭션을 시작하고, 이후에 발생하는 모든 쿼리는 이 트랜잭션 내에서 실행됩니다.

    트랜잭션을 롤백하는 방법은 Session::rollBack 메서드를 호출하는 것입니다. 이 메서드를 호출하면, 현재 트랜잭션 내에서 발생한 모든 쿼리는 취소되고, 데이터베이스의 상태는 트랜잭션을 시작하기 전으로 돌아갑니다.

    예를 들어, 다음과 같이 Session::startTransaction 메서드를 호출하고, 이후에 발생하는 쿼리를 롤백하는 방법을 보여줄 수 있습니다.

    #hostingforum.kr
    php
    
    // 트랜잭션을 시작합니다.
    
    $session->startTransaction();
    
    
    
    try {
    
        // 데이터를 삽입합니다.
    
        $session->insert('users', ['name' => 'John Doe', 'email' => 'john@example.com']);
    
    
    
        // 데이터를 업데이트합니다.
    
        $session->update('users', ['name' => 'Jane Doe'], ['email' => 'john@example.com']);
    
    
    
        // 트랜잭션을 커밋합니다.
    
        $session->commit();
    
    } catch (Exception $e) {
    
        // 트랜잭션을 롤백합니다.
    
        $session->rollBack();
    
    }
    
    

    2025-05-11 18:23

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

검색

게시물 검색