datasource
datasource는 커넥션을 획득하는 방법을 추상화한 인터페이스라고 학습했습니다. 근데 이번 장에서 Datasource TransactionManager는 JDBC 트랜잭션 관리라고 하셨는데 datasource라는 것은 JDBC에 국한되는 것이 아니라 JPA, hibernate에서도 쓰일 수 있는 것 아닌가요?
전에는 DB마다 커넥션을 얻는 방법, sql전달 방법등이 달라서 이걸 편하게 해주기 위해 나온 것이 JDBC이고 DriverManager를 통해서 url,id,pw를 넘겨서 해당 dbDriver를 얻어서 커넥션을 얻었는데 이제는 DriverManager를 사용하지 않고 Datasource만을 사용해서 DB에 접근하는데 그렇다면 Datasource가 DriverManager가 하는 역할까지 수행하기때문에 가능한 것인가요?
답변 1
2
안녕하세요, Lego 님. 공식 서포터즈 y2gcoder 입니다.
datasource는 커넥션을 획득하는 방법을 추상화한 인터페이스라고 학습했습니다. 근데 이번 장에서 Datasource TransactionManager는 JDBC 트랜잭션 관리라고 하셨는데 datasource라는 것은 JDBC에 국한되는 것이 아니라 JPA, hibernate에서도 쓰일 수 있는 것 아닌가요?
맞습니다. DatasourceTransactionManager 는 DataSource를 사용하는 트랜잭션매니저 구현체로 JDBC와 JDBC 를 사용하는 JPA, Hibernate에서 사용할 수 있습니다. 다만 JDBC에서 사용하는 트랜잭션 매니저라고 언급하신 이유는 JPA, Hibernate에서는 해당 기술들에 특화된 기능을 포함한 트랜잭션 매니저가 존재하고 그것을 사용하기 때문이라고 조심스럽게 생각합니다. JPA과 같은 ORM에서 제공하는 1차 캐시나, 지연 로딩과 같은 기능을 제공하기 위해서는 JDBC 수준의 트랜잭션 관리로는 어렵기 때문입니다.
전에는 DB마다 커넥션을 얻는 방법, sql전달 방법등이 달라서 이걸 편하게 해주기 위해 나온 것이 JDBC이고 DriverManager를 통해서 url,id,pw를 넘겨서 해당 dbDriver를 얻어서 커넥션을 얻었는데 이제는 DriverManager를 사용하지 않고 Datasource만을 사용해서 DB에 접근하는데 그렇다면 Datasource가 DriverManager가 하는 역할까지 수행하기때문에 가능한 것인가요?
맞습니다. 저도 그렇게 이해하고 있습니다.
감사합니다.
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
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
94
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
95
1
강의 14분쯤 Exception 질문
0
111
2





