개발자 Q&A

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

2025.04.24 00:39

mysqli::savepoint 사용에 대한 질문

목록
  • 클린아키텍처광 20시간 전 2025.04.24 00:39 새글
  • 7
    1
저는 mysqli::savepoint를 사용하여 트랜잭션을 관리하고 싶습니다.
하지만 savepoint를 설정하고 rollback을 하려면 어떻게 해야하나요?
mysqli::savepoint를 사용하여 rollback을 하는 방법을 알려주세요.

    댓글목록

    profile_image
    나우호스팅  20시간 전



    mysqli::savepoint를 설정한 후 rollback을 하려면, 다음과 같은 방법을 사용할 수 있습니다.

    1. savepoint를 설정한 후 rollback을 하려면, mysqli::release() 함수를 사용하여 savepoint를 삭제한 후 rollback을 합니다.
    2. rollback을 하기 전에, mysqli::commit() 함수를 사용하여 현재 트랜잭션을 커밋하지 않도록 합니다.
    3. rollback을 하기 위해 mysqli::rollback() 함수를 사용합니다.

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

    #hostingforum.kr
    php
    
    // 트랜잭션 시작
    
    mysqli_begin_transaction($conn);
    
    
    
    // savepoint 설정
    
    mysqli_savepoint($conn, 'savepoint1');
    
    
    
    // 데이터 삽입
    
    mysqli_query($conn, 'INSERT INTO 테이블명 VALUES (값1, 값2)');
    
    
    
    // rollback을 하기 전에 savepoint를 삭제
    
    mysqli_release_savepoint($conn, 'savepoint1');
    
    
    
    // rollback
    
    mysqli_rollback($conn);
    
    


    또는, 다음과 같이 코드를 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    // 트랜잭션 시작
    
    mysqli_begin_transaction($conn);
    
    
    
    // savepoint 설정
    
    mysqli_savepoint($conn, 'savepoint1');
    
    
    
    // 데이터 삽입
    
    mysqli_query($conn, 'INSERT INTO 테이블명 VALUES (값1, 값2)');
    
    
    
    // rollback
    
    mysqli_rollback_to_savepoint($conn, 'savepoint1');
    
    


    mysqli::savepoint를 사용하여 rollback을 하는 방법은 위와 같이 두 가지 방법이 있습니다.

    2025-04-24 00:40

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

검색

게시물 검색