집 >데이터 베이스 >MySQL 튜토리얼 >MySQL Advanced Ten - 트랜잭션 적용
1. 트랜잭션이란 무엇인가요?
트랜잭션 기술을 사용해야 하는 이유는 무엇인가요? 오늘날 많은 소프트웨어는 다중 사용자, 다중 코스, 다중 스레드를 사용하여 여러 사람이 동시에 사용할 수 있습니다. 데이터의 일관성을 유지하기 위해 트랜잭션이라는 개념이 제안되었습니다.
1. 데이터베이스가 트랜잭션을 지원하는지 확인하세요(InnoDB 지원).
show engines;
2. 현재 mysql의 기본 스토리지 엔진을 확인하시나요?
show variables like '%storage_engine%';
3. 특정 테이블의 스토리지 엔진을 확인하시나요?
show create table test;
4. 테이블 수납구조 수정?
InnoDB 테이블 생성: 테이블 생성 ... type=InnoDB;Alter table table_name type=InnoDB;
2. 예:
1. 🎜 >
create table account( aid int not null, accname varchar(20) not null, accmoney decimal(10,2) not null, primary key(aid))engine = innodb default charset = gbk;2. 두 개의 데이터를 계정 테이블에 삽입
insert into account values(1,'A',4000); insert into account values(2,'B',2000);3. 테이블의 트랜잭션을 시작합니다
start transaction;4. 제출 활성화
commit; set autocommit = 0;5. 다음 명령문을 실행합니다
<pre name="code" class="sql">update account set accmoney = accmoney - 1000 where aid = 1; update account set accmoney = accmoney + 1000 where aid = 2;6. 새 MySQL 명령 창을 열어 계정 테이블을 봅니다
select * from account;위의 수정된 지침이 데이터베이스에서 수정되지 않았기 때문에 데이터가 변경되지 않은 것을 알 수 있습니다.
7. 원본 창에서 쿼리하면 데이터가 변경된 것을 알 수 있습니다. 🎜>
select * from account;9. 다른 클라이언트에서 데이터를 확인하면 데이터가 변경된 것을 확인할 수 있습니다
commit;3 .트랜잭션 롤백 및 복원 시점
select * from account;
1. 트랜잭션 롤백
은 트랜잭션이 발생하기 전의 데이터 상태로 돌아갑니다. 롤백을 통해.
보충: 커밋 및 체인은 트랜잭션을 커밋한 후 새 트랜잭션이 다시 열리는 것을 의미합니다.
롤백 및 해제는 롤백 후 고객과의 연결이 끊어지는 것을 의미합니다.
2. 복원 지점(인스턴스)
set autocommit = 0; insert into account values(3,'C',3000); savepoint a1; insert into account values(4,'D',3000); savepoint a2; insert into account values(5,'E',3000); savepoint a3;
就会看到你插入的数据 如果你想回滚到某一状态只需rollback调用一下就行; 如:回到savepoint a1的状态쿼리문 실행
rollback to savepoint a1;
테이블에 새로운 데이터가 추가된 것을 볼 수 있습니다.
4. 트랜잭션 요약
트랜잭션에는
원자성, 일관성, 격리성, 내구성이라는 4가지 속성이 있어야 합니다. 이러한 네 가지 속성을 흔히 ACID 속성이라고 합니다.
원자성: 트랜잭션은 분할할 수 없는 작업 단위이며 트랜잭션에 포함된 모든 작업은 완료되거나 전혀 수행되지 않습니다.
일관성: 트랜잭션은 데이터베이스를 한 일관성 상태에서 다른 일관성 상태로 변경해야 합니다. 일관성과 원자성은 밀접한 관련이 있습니다.
격리: 트랜잭션의 실행은 다른 트랜잭션의 방해를 받을 수 없습니다. 즉, 트랜잭션에서 사용되는 내부 작업과 데이터는 다른 동시 트랜잭션과 격리되어 동시에 실행되는 트랜잭션이 서로 간섭할 수 없습니다.
내구성: 내구성도 영구적이 됩니다. 트랜잭션이 커밋되면 데이터베이스의 데이터에 대한 변경 사항은 영구적이어야 합니다. 후속 작업이나 실패는 이에 영향을 미치지 않습니다.
위 내용은 MySQL Advanced Ten - Transaction Application의 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!