인프런 커뮤니티 질문&답변

horious lee님의 프로필 이미지

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

주문 목록 검색, 취소

Controller에서 Repository 를 직접 사용할 때.

해결된 질문

19.10.10 22:32 작성

·

1.8K

12

간단한 조회는 Controller 에서 직접 Repository 를 사용하기도 한다. 라는 설명에 대한 질문입니다.

예제에서는 모든 Transaction 이 Service layer 에서 관리되는데 Controller에서 직접 Repository 를 접근할 때에는 tx 가 암묵적으로 생성되는 것인가요?

답변 2

16

김영한님의 프로필 이미지
김영한
지식공유자

2019. 10. 11. 00:31

안녕하세요^^ horious lee님

저는 실용적인 관점에서 컨트롤러에서 단순한 엔티티를 조회할 때 리포지토리를 직접 참조하기도 합니다.

이 경우 궁금해하시는 TX는 크게 2가지 방법으로 해결합니다.

1. 리포지토리 조회 기능에 명시적으로 읽기 트랜잭션을 적용한다.(@Tx(readOnly))

2. 리포지토리 조회 기능에 트랜잭션을 명시하지 않는다.

1번의 경우 리포지토리에서 데이터베이스 커넥션을 획득하고, DB와 트랜잭션을 시작합니다. 이것을 읽기 전용 트랜잭션 사용이라 합니다. (스프링 데이터 JPA는 이 방식을 사용합니다.)

2번의 경우는 트랜잭션을 시작하지 않고, 단순히 커넥션을 획득해서 데이터베이스에 바로 쿼리로 조회를 요청합니다. 이것을 트랜잭션 밖에서 읽기라 합니다. JPA에서 데이터를 변경할 때는 트랜잭션이 필수지만 읽기만 할 때는 트랜잭션이 없어도 동작합니다.

관련해서 자바 ORM 표준 JPA 프로그래밍 책 15.4.2 읽기 전용 쿼리의 성능 최적화 부분을 참고하시면 더 깊이 있는 내용을 이해할 수 있습니다^^

감사합니다.

0

horious lee님의 프로필 이미지
horious lee
질문자

2019. 10. 11. 23:26

답변 감사합니다.