inflearn logo
강의

Course

Instructor

Spring DB Part 1 - Core Principles of Data Access

Tx troubleshooting - Tx template

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

116

okputto

8 asked

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
안녕하세요

트랜잭션 템플릿은 하나의 DBMS 에서의 계좌이체 트랜잭션에서만 사용할 수 있을것 같은데요 맞을까요?
만일 2개의 DBMS 에서 원자성을 지키려면 어떻게 해야될까요?
시나리오는
ㅇ db 1 : 데이터 갱신

ㅇ db 2 : 데이터 갱신

ㅇ db 1 : 데이터 갱신

이고 3번째 스텝에서 exception 이 발생하면 어떻게 되나요?
감사합니다

spring mvc spring-jdbc

Answer 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

okputto님이 질문하신 트랜잭션 템플릿은 주로 하나의 DBMS 내에서 트랜잭션을 처리할 때 사용됩니다. 따라서 2개 이상의 이기종 DBMS에서 트랜잭션을 관리하고 원자성을 보장하기 위해서는 분산 트랜잭션 관리가 필요합니다.

분산 트랜잭션을 관리하는 방법 중 하나는 Java Transaction API(JTA)와 같은 분산 트랜잭션 서비스를 이용하는 것입니다. JTA를 통해 여러 DBMS에 걸친 트랜잭션을 관리하고 원자성을 보장할 수 있습니다.

말씀하신 시나리오에서 마지막 스텝에서 예외가 발생하는 경우, 분산 트랜잭션 관리자는 롤백을 수행하여 모든 관련 DBMS에서의 변경사항을 취소하여 일관성을 유지하게 됩니다.

도움이 되셨기를 바랍니다. 감사합니다.

관련 자료 확인 링크

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

27

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

49

1

jdbc 학습하다 궁금해서 질문드려요

0

80

1

정상이체와 이체중 예외발생 차이

0

68

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

86

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

58

2

데이터베이스 선택 관련 질문.

0

68

2

after 메서드 사용 유무

0

56

2

데이터베이스 접근 및 DB 락

0

52

1

@SpingBootTest, @TestConfiguration

0

55

1

Read Committed 격리 수준 사용 관련 질문

0

48

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

66

2

커리큘럼 관련 질문

0

76

1

서비서 계층 스프링 프레임워크 사용

0

87

1

validation(toMember)의 위치

0

83

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

165

2

member 상수 질문

0

120

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

153

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

108

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

94

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

95

1

강의 14분쯤 Exception 질문

0

111

2

memberId 맴버변수를 String 으로 잡은 이유

0

127

2