트랜잭션 사용 전 후 / 수동 오토 커밋
1. 이전 강의에서는 트랜잭션을 사용하지 않아 오토커밋이 되었고, 이번 강의에서는 트랜잭션을 사용해서 수동커밋이 된것으로 이해했는데 맞을까요?
2. 수동커밋이 맞다면, 수동 커밋이 되어서 롤백을 할 수 있는 건가요?
3. 이전 강의 까지는 트랜잭션을 사용하지 않고 DB 커넥션만 사용했다고 이해하면 되는 걸까요?
4. 제가 테스트 해보고 싶었던 것은 '스프링 DB 1편'에 있는 '트랜잭션 - DB 예제3 - 트랜잭션 실습'처럼 수동 커밋의 경우 한 세션에서는 데이터가 들어간것이 보이지만 다른 한 세션에서는 안 보이는 것을 테스트 해보고 싶었습니다.
그래서 랜잭션 롤백 부분 코드( transactionManager.rollback(status); )를 주석처리 하였고, H2 DB를 2개 띄웠습니다. 이 상태에서 save(), updateItem(), findItems()를 각각 실행해서 확인해 보면 두 세션 모두 데이터가 보이는 것을 확인할 수 있었습니다.
커밋을 안했고 롤백도 안했는데 둘다 데이터가 보이는 걸까요?
답변 1
0
안녕하세요. IwisekimI님, 공식 서포터즈 y2gcoder입니다.
1. 2.
=> 맞습니다. 트랜잭션을 열어서 수동 커밋 모드로 바꾸었기 때문에 원하는 시점에 DB에 커밋할 수 있게 되었습니다.
3.
=> 저는 트랜잭션이 하나의 작업 단위라고 생각합니다. 이전까지의 코드에서는 SQL문 하나당 하나의 트랜잭션을 가졌다면, 이제는 트랜잭션을 직접 열어서 메서드가 끝날 때 롤백(테스트 코드)을 하도록 변경해줬기 때문에, 메서드 하나 당 하나의 트랜잭션을 가지게 되었다고 이해했습니다.
4.
=> 해당 부분에서 애플리케이션 레벨에서 보려면 생각보다 귀찮은 과정이 필요할 것 같습니다. 저라면 보길 원하는 테스트 코드(save 같은)에 DB저장하는 메서드 후 쓰레드를 걸어 잠시 멈춰놓고, save에서 넣은 값이 H2 DB 콘솔에서 보이는지 체크할 것 같습니다. 왜냐하면 이미 애플리케이션과 H2 DB 콘솔은 다른 세션 단위기 때문입니다 :)
감사합니다.
RepositoryTest의 패키지 위치가 domain인 이유
0
23
2
REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!
0
28
1
update()에 사용하는 setter 질문드립니다.
0
46
1
SQL 중심적 개발의 문제점에 대한 질문
0
71
1
혹시 Containing 을 안쓰신 이유가 있을까요?
0
82
2
[공유] 스프링부트 4.x 버전 mybatis 연동
0
170
1
@repository 어노테이션
0
88
3
ItemService
0
56
1
논리 커밋, 물리 커밋 질문드립니다.
0
53
1
내부 트랜잭션 커밋은 필수인가요?
0
55
1
프록시 커넥션 객체를 반환할 때 생성하는건가요?
0
53
1
Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)
2
176
2
JPQL 대신 네이티브 쿼리를 사용해야 하는 경우
0
76
1
@EventListener(ApplicationReadyEvent.class) 관련
0
87
1
트랜잭션 동기화 매니저와 데이터 소스
0
75
1
DB 관련 강의 개설 계획은 없으신건가요?
0
132
2
물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요
0
93
1
스프링 3 버전 이상 rollbackFor 변경된듯요
1
110
1
트랜잭션 전파 질문.
0
86
1
프로젝트 오픈 에러
0
124
1
외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다
0
82
2
같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환
0
71
1
h2 인메모리 테스트중 예약어 충돌날 경우 대처방법
0
99
1
커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문
0
96
2





