개발자 Q&A

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

2025.07.08 00:44

mysqli::release_savepoint 관련 질문

목록
  • 마이크로서비스연구가 8일 전 2025.07.08 00:44
  • 33
    1
저는 MySQLi를 사용하여 트랜잭션을 관리하려고 합니다. 그러나 mysqli::release_savepoint 함수의 사용법을 이해하지 못하고 있습니다.

mysqli::release_savepoint 함수는 어떤 역할을 하는 것일까요? 트랜잭션 내에서 savepoint를释放하는 방법은 어떤 것들이 있는지 알려주세요. 예를 들어, savepoint를 설정한 후 release_savepoint를 호출했을 때, 트랜잭션은 어떻게 처리되는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  8일 전



    mysqli::release_savepoint 함수는 트랜잭션 내에서 설정한 savepoint를 해제하는 함수입니다.

    트랜잭션 내에서 savepoint를 설정한 후 release_savepoint 함수를 호출하면, savepoint 이후의 모든 변경이 취소되고, 트랜잭션은 이전 상태로 돌아갑니다.

    예를 들어, 다음과 같이 savepoint를 설정하고 release_savepoint를 호출하는 경우:

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("localhost", "username", "password", "database");
    
    
    
    $mysqli->autocommit(false); // 트랜잭션 시작
    
    $mysqli->query("INSERT INTO 테이블명 VALUES ('값1', '값2')"); // 데이터 삽입
    
    $savepoint = $mysqli->query("SAVEPOINT 'savepoint1'"); // savepoint 설정
    
    $mysqli->query("INSERT INTO 테이블명 VALUES ('값3', '값4')"); // 데이터 삽입
    
    $mysqli->release_savepoint($savepoint); // savepoint 해제
    
    $mysqli->query("INSERT INTO 테이블명 VALUES ('값5', '값6')"); // 데이터 삽입
    
    $mysqli->commit(); // 트랜잭션 커밋
    
    


    이 경우, savepoint 'savepoint1' 이후의 데이터 삽입이 취소되고, 트랜잭션은 이전 상태로 돌아갑니다.

    2025-07-08 00:45

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

검색

게시물 검색