Member테이블과 조인을 하는 이유가 궁금합니다.
356
작성한 질문수 1
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
답변 2
1
안녕하세요. 김용완님, 공식 서포터즈 David입니다.
.
우선, 강의 에서는 findAll 메서드가 주문검색을 위해 만들어졌습니다. 파라미터가 이미 OrderSearch이죠.
주문 검색시 회원이름(Order의 멤버변수인 member가 필요)이 필수적으로 나타나게 되어있습니다.
따라서 검색 결과에 필요한 데이터(예를들어 Member)를 한 번에 들고오면 됩니다. 굳이 Order를 조회한 다음 Member를 별도로 조회할 필요가 없습니다. 오히려 Member 조회쿼리가 1번 더 나가야하는게 문제입니다.
즉, 주문 검색의 결과로 회원 정보 포함된 주문 정보가 필요하므로 Order를 조회할 때 Member와 조인해서 필요한 데이터를 한 번에 가져오는 것입니다.
물론 경우에 따라 지연로딩이 필요한 경우가 있지만 이번 케이스는 해당되지 않습니다.
.
감사합니다.
0
답변 감사합니다.
그럼 성능적인 이슈라고 이해하면 될까요?
member를 별도로 조회했다는건 제가 조회했다는게 아니라, 예를들어
return em.createQuery("select o from Order o where o.member = :member and o.status = :status", Order.class)
.setParameter("member", member)
.setParameter("status", status)
.getResultList();
위와같이 조인 없이 호출했을 때, JPA 내부에서 자동으로 order에 대한 select와 member의 대한 select, 총 "2개"의 select문을 날려서, 조인쿼리와 비슷하게 동작하더라구요.
결론적으로, 위와같이 조인을 사용했을 땐, 내부적으로 불필요하게 2번의 select문이 호출되지 않으므로 성능적인 개선이 된다 -> 정도로 이해했는데 맞나요?
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
28
1
sdk 설정 오류
0
70
2
오탈자 - @Transactional
0
63
1
src/test/resources 테스트 경로 문제
0
64
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
70
1
MemberRepositoryTest 실행오류
0
90
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
197
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
154
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
57
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
82
1
기본 생성자
0
67
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
107
1
멤버서비스테스트 부분에서 막힙니다.
0
175
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
124
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
129
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
122
1
24분 27초 연관관계 편의 메서드 위치
0
118
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
114
2
빌드 툴, Gradle
0
65
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
82
2
Repository에서 EntityManager 주입 방식 차이
0
97
1
롬복과 사용자 정의 setter 메서드
0
78
1
주문 목록 조회 fetch join 질문드립니다
0
91
1
dirty checking 질문드립니다.
0
87
1





