해결된 질문
작성
·
1.8K
12
간단한 조회는 Controller 에서 직접 Repository 를 사용하기도 한다. 라는 설명에 대한 질문입니다.
예제에서는 모든 Transaction 이 Service layer 에서 관리되는데 Controller에서 직접 Repository 를 접근할 때에는 tx 가 암묵적으로 생성되는 것인가요?
답변 2
16
안녕하세요^^ horious lee님
저는 실용적인 관점에서 컨트롤러에서 단순한 엔티티를 조회할 때 리포지토리를 직접 참조하기도 합니다.
이 경우 궁금해하시는 TX는 크게 2가지 방법으로 해결합니다.
1. 리포지토리 조회 기능에 명시적으로 읽기 트랜잭션을 적용한다.(@Tx(readOnly))
2. 리포지토리 조회 기능에 트랜잭션을 명시하지 않는다.
1번의 경우 리포지토리에서 데이터베이스 커넥션을 획득하고, DB와 트랜잭션을 시작합니다. 이것을 읽기 전용 트랜잭션 사용이라 합니다. (스프링 데이터 JPA는 이 방식을 사용합니다.)
2번의 경우는 트랜잭션을 시작하지 않고, 단순히 커넥션을 획득해서 데이터베이스에 바로 쿼리로 조회를 요청합니다. 이것을 트랜잭션 밖에서 읽기라 합니다. JPA에서 데이터를 변경할 때는 트랜잭션이 필수지만 읽기만 할 때는 트랜잭션이 없어도 동작합니다.
관련해서 자바 ORM 표준 JPA 프로그래밍 책 15.4.2 읽기 전용 쿼리의 성능 최적화 부분을 참고하시면 더 깊이 있는 내용을 이해할 수 있습니다^^
감사합니다.
0