>데이터 베이스 >MySQL 튜토리얼 >MySQL Advanced Ten - 트랜잭션 적용

MySQL Advanced Ten - 트랜잭션 적용

黄舟
黄舟원래의
2016-12-29 16:47:391001검색

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. 원본 창에서 쿼리하면 데이터가 변경된 것을 알 수 있습니다. 🎜>

8. 물리적 커밋 제출
select * from account;

9. 다른 클라이언트에서 데이터를 확인하면 데이터가 변경된 것을 확인할 수 있습니다
commit;

3 .트랜잭션 롤백 및 복원 시점
select * from account;

1. 트랜잭션 롤백

은 트랜잭션이 발생하기 전의 데이터 상태로 돌아갑니다. 롤백을 통해.

보충: 커밋 및 체인은 트랜잭션을 커밋한 후 새 트랜잭션이 다시 열리는 것을 의미합니다.

롤백 및 해제는 롤백 후 고객과의 연결이 끊어지는 것을 의미합니다.

2. 복원 지점(인스턴스)

데이터베이스 정보 보기
set autocommit = 0;  
insert into account values(3,&#39;C&#39;,3000);  
savepoint a1;  
insert into account values(4,&#39;D&#39;,3000);  
savepoint a2;  
insert into account values(5,&#39;E&#39;,3000);  
savepoint a3;

就会看到你插入的数据

如果你想回滚到某一状态只需rollback调用一下就行;

如:回到savepoint a1的状态
쿼리문 실행
rollback to savepoint a1;

테이블에 새로운 데이터가 추가된 것을 볼 수 있습니다.

4. 트랜잭션 요약

트랜잭션에는

원자성, 일관성, 격리성, 내구성이라는 4가지 속성이 있어야 합니다. 이러한 네 가지 속성을 흔히 ACID 속성이라고 합니다.

원자성: 트랜잭션은 분할할 수 없는 작업 단위이며 트랜잭션에 포함된 모든 작업은 완료되거나 전혀 수행되지 않습니다.

일관성: 트랜잭션은 데이터베이스를 한 일관성 상태에서 다른 일관성 상태로 변경해야 합니다. 일관성과 원자성은 밀접한 관련이 있습니다.

격리: 트랜잭션의 실행은 다른 트랜잭션의 방해를 받을 수 없습니다. 즉, 트랜잭션에서 사용되는 내부 작업과 데이터는 다른 동시 트랜잭션과 격리되어 동시에 실행되는 트랜잭션이 서로 간섭할 수 없습니다.

내구성: 내구성도 영구적이 됩니다. 트랜잭션이 커밋되면 데이터베이스의 데이터에 대한 변경 사항은 영구적이어야 합니다. 후속 작업이나 실패는 이에 영향을 미치지 않습니다.

위 내용은 MySQL Advanced Ten - Transaction Application의 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


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