>데이터 베이스 >MySQL 튜토리얼 >MySQL 관계형 데이터베이스 트랜잭션의 ACID 특성 및 구현 방법

MySQL 관계형 데이터베이스 트랜잭션의 ACID 특성 및 구현 방법

PHPz
PHPz앞으로
2023-05-28 17:01:271750검색

1. 거래의 자세한 ACID 특성

ACID는 거래가 정확하고 신뢰할 수 있음을 보장하기 위해 보유해야 하는 네 가지 특성입니다.

  • 원자성: 거래의 작업이 동시에 성공하거나 실패합니다.

  • 일관성: 데이터베이스 트랜잭션은 데이터의 무결성과 비즈니스 로직의 일관성을 파괴할 수 없습니다.

  • 격리: 거래는 다른 거래의 운영에 영향을 미치지 않습니다.

  • 내구성: 트랜잭션이 완료된 후 트랜잭션으로 인한 수정 사항은 데이터베이스에 유지되어야 하며 롤백되지 않습니다.

A가 B에게 100위안을 이체하는 예:

  • 원자성: A가 100위안을 잃고 B가 100위안을 받는 경우가 동시에 발생합니다.

  • 일관성: A의 계좌는 100위안 손실 이후 마이너스가 될 수 없습니다.

  • 격리: 이 거래를 실행하는 동안 거래 B를 실행하여 계정 A가 1위안을 잃는 경우 최종 손실은 101위안이 되어야 하며 둘은 서로 영향을 미치지 않습니다.

  • 지속성: A의 계정은 100위안을 잃은 후 다시 되돌릴 수 없습니다.

2. MySQL 트랜잭션 구현

MySQL 트랜잭션은 InnoDB 스토리지 엔진에 의해 구현됩니다.

다음 명령을 사용하여 명시적으로 트랜잭션을 시작할 수 있습니다.

start transaction / (Begin);
#一条或多条sql语句
Commit;

또한 자동 커밋(autocommit) 모드에서 자동 커밋이 해제된 경우(autocommit) 모드에서 실행하는 각 SQL 문은 독립적인 트랜잭션입니다. , 모든 SQL 문은 커밋 또는 롤백이 실행되고 트랜잭션이 종료되고 다른 트랜잭션이 시작될 때까지 하나의 트랜잭션에 있습니다.

MySQL 트랜잭션의 ACID 특성은 다음 메커니즘으로 구현됩니다.

  • 원자성: 실행 취소 로그, 논리적 로그, SQL 실행과 관련된 정보를 기록합니다. 롤백이 발생하면 InnoDB는 실행 취소 로그의 내용을 기반으로 이전 작업과 반대되는 작업을 수행합니다

  • 지속성: redo 로그 트랜잭션이 커밋되면 fsync 인터페이스가 호출되어 리두 로그를 플러시합니다. .

  • 격리: MVCC를 사용한 잠금 메커니즘.

  • 일관성: 데이터베이스 자체의 디자인.

3. Gorm 트랜잭션 사용

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를 참조할 수 있습니다. 자세한 소개

4. Spring 트랜잭션 사용

public class AClass {

    @Transactional(rollbackFor = Exception.class)
    public void aFunction() {
        //todo: 数据库操作A(增,删,该)
    }
}

@Transactional 주석을 공용 메소드에 추가해야 하며, 전용 및 보호 메소드는 유효하지 않습니다.

일반적으로 @Transactional 주석을 메서드에 추가하는 것이 좋습니다. 왜냐하면 @Transactional은 클래스나 인터페이스에 직접 추가되고 @Transactional 주석은 클래스나 인터페이스의 모든 공용 메서드에 적용되기 때문입니다. 성능.

위 내용은 MySQL 관계형 데이터베이스 트랜잭션의 ACID 특성 및 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제