inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 2편 - 데이터 접근 활용 기술

테스트 - 데이터 롤백

트랜잭션 및 커넥션 관련 질문 드립니다.

105

오리쉐리

작성한 질문수 108

0

안녕하세요. 앞서 db1강의에서 트랜잭션 관련 내용을 바탕으로 커넥션 관련해서 제가 이해하는 바가 맞는지 질문드립니다..!

 

 

트랜잭션 및 커넥션 관련해서 이렇게 이해하면서 정리해보았는데, 이렇게 이해하면 될까요?

 

spring mvc jpa querydsl spring-data-mybatis spring-jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 오리쉐리님.

트랜잭션과 커넥션에 대해 정리해주신 내용은 대부분 정확하게 이해하고 계신 것 같습니다. 간단히 요약하자면, JdbcTemplate을 사용하여 데이터베이스 작업을 수행할 때, 트랜잭션이 설정되어 있으면 해당 트랜잭션 내에서 커넥션을 관리하게 되고, 그렇지 않으면 자동 커밋 모드로 동작하여 즉시 데이터베이스에 반영됩니다.

트랜잭션이 시작된 경우와 그렇지 않은 경우 모두 DataSourceUtils.getConnection()을 통해 커넥션을 획득하며, 이를 통해 SQL 쿼리를 실행하게 됩니다. 트랜잭션이 설정되어 있다면, 커넥션은 트랜잭션 동기화 매니저에 의해 관리되고, 커밋 또는 롤백 시점까지 유지됩니다. 반면, 트랜잭션이 없을 경우에는 자동 커밋 모드로 바로 반영됩니다.

트랜잭션 관리에 대해 더 자세한 내용을 참고하시려면 트랜잭션 매니저가 커넥션을 얻어오는 방법 질문를 확인해보시면 좋을 것 같습니다. 이 게시물에서는 트랜잭션 매니저가 커넥션을 어떻게 얻고 반환하는지에 대한 내용을 다루고 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

RepositoryTest의 패키지 위치가 domain인 이유

0

29

2

REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!

0

29

1

update()에 사용하는 setter 질문드립니다.

0

47

1

SQL 중심적 개발의 문제점에 대한 질문

0

72

1

혹시 Containing 을 안쓰신 이유가 있을까요?

0

83

2

[공유] 스프링부트 4.x 버전 mybatis 연동

0

173

1

@repository 어노테이션

0

89

3

ItemService

0

58

1

논리 커밋, 물리 커밋 질문드립니다.

0

54

1

내부 트랜잭션 커밋은 필수인가요?

0

57

1

프록시 커넥션 객체를 반환할 때 생성하는건가요?

0

54

1

Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)

2

178

2

JPQL 대신 네이티브 쿼리를 사용해야 하는 경우

0

77

1

@EventListener(ApplicationReadyEvent.class) 관련

0

88

1

트랜잭션 동기화 매니저와 데이터 소스

0

76

1

DB 관련 강의 개설 계획은 없으신건가요?

0

133

2

물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요

0

94

1

스프링 3 버전 이상 rollbackFor 변경된듯요

1

112

1

트랜잭션 전파 질문.

0

87

1

프로젝트 오픈 에러

0

126

1

외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다

0

83

2

같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환

0

72

1

h2 인메모리 테스트중 예약어 충돌날 경우 대처방법

0

102

1

커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문

0

98

2