• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

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

19.10.10 22:32 작성 조회수 1.53k

12

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

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

답변 2

·

답변을 작성해보세요.

15

안녕하세요^^ horious lee님

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

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

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

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

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

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

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

감사합니다.

0

답변 감사합니다.