집 >데이터 베이스 >MySQL 튜토리얼 >MySQL 관계형 데이터베이스 트랜잭션의 ACID 특성 및 구현 방법
ACID는 거래가 정확하고 신뢰할 수 있음을 보장하기 위해 보유해야 하는 네 가지 특성입니다.
원자성: 거래의 작업이 동시에 성공하거나 실패합니다.
일관성: 데이터베이스 트랜잭션은 데이터의 무결성과 비즈니스 로직의 일관성을 파괴할 수 없습니다.
격리: 거래는 다른 거래의 운영에 영향을 미치지 않습니다.
내구성: 트랜잭션이 완료된 후 트랜잭션으로 인한 수정 사항은 데이터베이스에 유지되어야 하며 롤백되지 않습니다.
A가 B에게 100위안을 이체하는 예:
원자성: A가 100위안을 잃고 B가 100위안을 받는 경우가 동시에 발생합니다.
일관성: A의 계좌는 100위안 손실 이후 마이너스가 될 수 없습니다.
격리: 이 거래를 실행하는 동안 거래 B를 실행하여 계정 A가 1위안을 잃는 경우 최종 손실은 101위안이 되어야 하며 둘은 서로 영향을 미치지 않습니다.
지속성: A의 계정은 100위안을 잃은 후 다시 되돌릴 수 없습니다.
MySQL 트랜잭션은 InnoDB 스토리지 엔진에 의해 구현됩니다.
다음 명령을 사용하여 명시적으로 트랜잭션을 시작할 수 있습니다.
start transaction / (Begin); #一条或多条sql语句 Commit;
또한 자동 커밋(autocommit) 모드에서 자동 커밋이 해제된 경우(autocommit) 모드에서 실행하는 각 SQL 문은 독립적인 트랜잭션입니다. , 모든 SQL 문은 커밋 또는 롤백이 실행되고 트랜잭션이 종료되고 다른 트랜잭션이 시작될 때까지 하나의 트랜잭션에 있습니다.
MySQL 트랜잭션의 ACID 특성은 다음 메커니즘으로 구현됩니다.
원자성: 실행 취소 로그, 논리적 로그, SQL 실행과 관련된 정보를 기록합니다. 롤백이 발생하면 InnoDB는 실행 취소 로그의 내용을 기반으로 이전 작업과 반대되는 작업을 수행합니다
지속성: redo 로그 트랜잭션이 커밋되면 fsync 인터페이스가 호출되어 리두 로그를 플러시합니다. .
격리: MVCC를 사용한 잠금 메커니즘.
일관성: 데이터베이스 자체의 디자인.
Go 언어 Gorm은 트랜잭션 작업을 지원합니다:
db.Transaction(func(tx *gorm.DB) error { // 在事务中执行一些 db 操作(从这里开始,您应该使用 'tx' 而不是 'db') if err := tx.Create(&Animal{Name: "Giraffe"}).Error; err != nil { // 返回任何错误都会回滚事务 return err } if err := tx.Create(&Animal{Name: "Lion"}).Error; err != nil { return err } // 返回 nil 提交事务 return nil })
또한 중첩 트랜잭션과 수동 트랜잭션 등이 있습니다. 중국어 문서인 Go GORM Transactions를 참조할 수 있습니다. 자세한 소개
public class AClass { @Transactional(rollbackFor = Exception.class) public void aFunction() { //todo: 数据库操作A(增,删,该) } }
@Transactional 주석을 공용 메소드에 추가해야 하며, 전용 및 보호 메소드는 유효하지 않습니다.
일반적으로 @Transactional 주석을 메서드에 추가하는 것이 좋습니다. 왜냐하면 @Transactional은 클래스나 인터페이스에 직접 추가되고 @Transactional 주석은 클래스나 인터페이스의 모든 공용 메서드에 적용되기 때문입니다. 성능.
위 내용은 MySQL 관계형 데이터베이스 트랜잭션의 ACID 특성 및 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!