inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

정리

Mybatis에서 Connection의 생명주기 및 Pooling Proxy객체

274

kate

작성한 질문수 23

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]

제목과 같습니다.
Mybatis에서의 Connection 생명주기와
커넥션풀을 연동했을때의 Connection 생명주기가 궁금합니다.

Mybatis에서 커넥션풀을 적용한다고 가정합니다.
만약 하나의 기능 즉, 하나의 쓰레드 단위로 쿼리를 호출하는 매퍼 메소드를 4번 호출한다면 이때 커넥션은 Mapper를 통해 호출하는 DAO 메소드 단위로 Pool에서 4번 꺼내는것인지?
만약 그렇다면, 4번 꺼내는 객체들이 앞서 배운 내용처럼 처음 Pool에서 꺼내서 사용하고 반환한 동일한 Connection 객체를 다시 꺼내어 재사용 하는건지 궁금합니다!

또한 Transcation Rollback 되는것도 동일한 Connection, 동일한 Session에 의한것과 연관성이 있는건지도 궁금합니다.
제가 이해한 부분은 아래와 같습니다.
커넥션풀을 사용하면 커넥션풀에 각각 다른 커넥션이 생성됨(10개)

하나의 커넥션당 하나의 세션이 생성되며, 커넥션의 생명주기에 종속되어 있다.

세션은 트랜잭션을 시작하고 커밋을 관리한다.

커넥션 풀을 사용하면 하나의 스레드내에 각각의 쿼리에 대한 작업 단위가 동일한 커넥션을 반환받는다.

커넥션이 동일하다면 세션도 동일하므로 하나의 트랜잭션으로 관리된다?
이게 맞을까요?

spring mvc spring-jdbc

답변 1

0

김영한

안녕하세요. kate님

커넥션의 생명주기는 트랜잭션을 어디에서 실행하는 가에 따라서 달라집니다.

예를 들어서 서비스에서 트랜잭션을 시작했다면 해당 트랜잭션이 끝날 때 까지 모두 같은 데이터베이스 커넥션이 사용됩니다.

만약 서비스에서 트랜잭션을 시작하지 않았다면, 각각의 SQL이 실행될 때 마다 다른 커넥션이 사용되고 커넥션 풀에 반납됩니다.

감사합니다.

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

0

31

2

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

0

50

1

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

0

81

1

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

0

68

2

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

0

87

1

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

0

82

2

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

0

58

2

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

0

68

2

after 메서드 사용 유무

0

56

2

데이터베이스 접근 및 DB 락

0

54

1

@SpingBootTest, @TestConfiguration

0

56

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

109

1

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

0

116

1

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

0

97

1

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

0

97

1

강의 14분쯤 Exception 질문

0

114

2