Notice
Recent Posts
Recent Comments
Link
«   2024/05   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
Archives
Today
Total
관리 메뉴

개발자되기 프로젝트

트랜잭션 - DB 예제2 - 자동 커밋, 수동 커밋 본문

인프런/[인프런] 스프링 DB 1편 - 데이터 접근 핵심 원리

트랜잭션 - DB 예제2 - 자동 커밋, 수동 커밋

Seung__ 2022. 6. 1. 17:22

Schema 준비

drop table member if exists;
create table member (
member_id varchar(10),
money integer not null default 0,
primary key (member_id)
);

 

1. 자동 커밋

  • 자동 커밋으로 설정하면 각각의 쿼리 실행 직후에 자동으로 커밋을 호출한다.
  • 따라서 커밋이나 롤백을 직접 호출하지 않아도 되는 편리함이 있다. 
  • 하지만 쿼리를 하나하나 실행할 때 마다 자동으로 커밋이 되어버리기 때문에 
    우리가 원하는 트랜잭션 기능을 제대로 사용할 수 없다.
set autocommit true; //자동 커밋 모드 설정
insert into member(member_id, money) values ('data1',10000); //자동 커밋
insert into member(member_id, money) values ('data2',10000); //자동 커밋
  • 따라서 commit , rollback 을 직접 호출하면서 트랜잭션 기능을 제대로 수행하려면 수동 커밋을 사용

 

2. 수동 커밋

set autocommit false; //수동 커밋 모드 설정
insert into member(member_id, money) values ('data3',10000);
insert into member(member_id, money) values ('data4',10000);
commit; //수동 커밋

 

  • 보통 자동 커밋 모드가 기본으로 설정된 경우가 많기 때문에, 
  • 수동 커밋 모드로 설정하는 것을 트랜잭션을 시작한다고 표현할 수 있다.(수동 commit 설정  = transaction 시작)
  • 수동 커밋 설정을 하면 이후에 꼭 commit , rollback 을 호출해야 한다.
  • 참고로 수동 커밋 모드나 자동 커밋 모드는 한번 설정하면 해당 세션에서는 계속 유지된다. 
  • 중간에 변경하는것은 가능하다.
Comments