>  기사  >  데이터 베이스  >  COMMIT TRANSACTION 누락이 자동으로 트랜잭션을 롤백합니까?

COMMIT TRANSACTION 누락이 자동으로 트랜잭션을 롤백합니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-24 15:12:02886검색

Does COMMIT TRANSACTION Omission Automatically Rollback Transactions?

COMMIT TRANSACTION이 생략된 경우 자동 롤백

주어진 SQL 문에서:

START TRANSACTION;
BEGIN;
INSERT INTO prp_property1 (module_name,environment_name,NAME,VALUE) VALUES ('','production','','300000');

/** Assume there is syntax error SQL here...**/
Blah blah blah

DELETE FROM prp_property1 WHERE environment_name = 'production';
COMMIT TRANSACTION;

다음과 같은 질문이 발생합니다. 구문 오류로 인해 COMMIT TRANSACTION 문에 도달하지 못하므로 트랜잭션이 자동으로 롤백됩니다.

트랜잭션 롤백 동작

가정과 달리 트랜잭션은 자동으로 롤백되지 않습니다. 오류가 발생하면 롤백됩니다. 이 동작은 일반적으로 클라이언트 응용 프로그램 설정에서 구현됩니다. 예를 들어, MySQL 명령줄 클라이언트는 오류 발생 시 실행을 종료하고 종료하며, 이로 인해 진행 중인 모든 트랜잭션이 롤백됩니다.

사용자 정의 애플리케이션을 개발할 때 개발자는 트랜잭션 롤백 정책을 제어할 수 있습니다. 그러나 특정 예외가 있습니다.

  • 데이터베이스 연결을 종료하면 항상 진행 중인 트랜잭션이 롤백됩니다.
  • 교착 상태 또는 잠금 대기 시간 초과도 암시적으로 롤백을 트리거합니다.

이러한 특정 시나리오를 제외하면 오류로 인해 자동으로 롤백이 발생하지 않습니다. 오류가 반환되고 개발자는 오류에도 불구하고 트랜잭션 커밋을 포함하여 다음 작업 과정을 자유롭게 결정할 수 있습니다.

위 내용은 COMMIT TRANSACTION 누락이 자동으로 트랜잭션을 롤백합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.