개발자 Q&A

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

2025.03.31 20:00

mysqli::begin_transaction와 mysqli::commit()의 차이점

목록
  • 마이크로서비스연구가 2일 전 2025.03.31 20:00
  • 1
    1
제가 공부하던 중 mysqli::begin_transaction() 함수와 mysqli::commit() 함수를 사용하여 데이터베이스 트랜잭션을 처리하는 방식에 대해 혼란이 있습니다.

mysqli::begin_transaction() 함수는 데이터베이스 트랜잭션을 시작하는 함수로, 이 함수를 호출하면 데이터베이스의 변경이 트랜잭션 내에서 처리됩니다. 만약 트랜잭션 내에서 오류가 발생하면 mysqli::rollback() 함수를 호출하여 트랜잭션을 취소할 수 있습니다.

mysqli::commit() 함수는 데이터베이스 트랜잭션을 완료하는 함수로, 이 함수를 호출하면 트랜잭션 내의 변경이 데이터베이스에 저장됩니다.

제가 궁금한 점은 mysqli::begin_transaction() 함수를 호출한 후 mysqli::commit() 함수를 호출하지 않고 mysqli::rollback() 함수를 호출했을 때, 데이터베이스에 어떤 영향을 미치는지 궁금합니다.

예를 들어, 다음과 같은 코드를 작성했을 때, mysqli::begin_transaction() 함수를 호출한 후 mysqli::commit() 함수를 호출하지 않고 mysqli::rollback() 함수를 호출했을 때, 데이터베이스의 상태는 어떻게 될까요?

php

$mysqli = new mysqli('localhost', 'root', 'password', 'database');



$mysqli->begin_transaction();



$mysqli->query('UPDATE table_name SET column_name = 1 WHERE id = 1');

$mysqli->query('UPDATE table_name SET column_name = 2 WHERE id = 2');



// mysqli::commit() 함수를 호출하지 않고 mysqli::rollback() 함수를 호출합니다.

$mysqli->rollback();



$mysqli->close();



이 코드를 실행했을 때, 데이터베이스의 상태는 어떻게 될까요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    mysqli::begin_transaction() 함수를 호출한 후 mysqli::commit() 함수를 호출하지 않고 mysqli::rollback() 함수를 호출하면, 데이터베이스의 변경이 취소됩니다.

    이 코드를 실행했을 때, 데이터베이스의 상태는 다음과 같습니다.

    - table_name 테이블의 id = 1 인 레코드의 column_name 값은 변경되지 않습니다.
    - table_name 테이블의 id = 2 인 레코드의 column_name 값은 변경되지 않습니다.

    즉, 데이터베이스의 변경이 모두 취소되어 원래 상태로 돌아갑니다.

    이러한 동작은 mysql이 트랜잭션을 지원하는 특징으로, 데이터베이스의 일관성을 유지하기 위해 트랜잭션 내의 변경을 취소할 수 있도록 함으로써 데이터베이스의 안정성을 보장합니다.

    2025-03-31 20:01

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

검색

게시물 검색