개발자 Q&A

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

2025.06.26 23:10

mysqli::savepoint에 대한 질문

목록
  • PostgreSQL마법사 7시간 전 2025.06.26 23:10 새글
  • 4
    1
제가 현재 MYSQLI를 이용하여 트랜잭션을 처리 중입니다.
트랜잭션 내에서 savepoint를 설정하고 rollback하는 부분에 대해 질문을 드리겠습니다.

트랜잭션을 시작한 후 savepoint를 설정한 후 rollback을 수행하면, rollback이 수행된 이후 트랜잭션은 종료되나요?

아니면 rollback이 수행된 이후 다시 트랜잭션을 시작할 수 있나요?

그리고 rollback이 수행된 이후 다시 savepoint를 설정할 수 있나요?

아니면 이전의 savepoint를 재사용하나요?

    댓글목록

    profile_image
    나우호스팅  6시간 전



    mysqli::savepoint에 대한 질문에 대한 답변입니다.

    트랜잭션을 시작한 후 savepoint를 설정한 후 rollback을 수행하면, rollback이 수행된 이후 트랜잭션은 종료되지 않습니다. 트랜잭션은 rollback이 수행된 이후 다시 시작할 수 있습니다.

    rollback이 수행된 이후 다시 savepoint를 설정할 수 있습니다. 이전의 savepoint를 재사용할 수 있습니다.

    예를 들어, 다음 코드를 참고하세요.

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("호스트", "이름", "비밀번호", "데이터베이스");
    
    
    
    $mysqli->autocommit(false); // 트랜잭션 시작
    
    
    
    $mysqli->query("INSERT INTO 테이블명 VALUES ('값1', '값2')");
    
    
    
    $mysqli->query("SAVEPOINT 저장점명"); // savepoint 설정
    
    
    
    $mysqli->query("INSERT INTO 테이블명 VALUES ('값3', '값4')");
    
    
    
    $mysqli->rollback(); // rollback 수행
    
    
    
    $mysqli->query("INSERT INTO 테이블명 VALUES ('값5', '값6')"); // 트랜잭션 다시 시작
    
    
    
    $mysqli->query("SAVEPOINT 저장점명2"); // savepoint 다시 설정
    
    


    위 코드에서, rollback이 수행된 이후 다시 트랜잭션을 시작하고 savepoint를 다시 설정할 수 있습니다. 이전의 savepoint를 재사용할 수 있습니다.

    2025-06-26 23:11

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

검색

게시물 검색