인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

신동훈님의 프로필 이미지
신동훈

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

주문 조회 V5: JPA에서 DTO 직접 조회 - 컬렉션 조회 최적화

em.createQuery 에서 i.name과 oi.item.name 의 차이

작성

·

245

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://docs.google.com/document/d/1j0jcJ9EoXMGzwAA2H0b9TOvRtpwlxI5Dtn3sRtuXQas/edit#heading=h.w2tomwsznga7)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://docs.google.com/document/d/1xCQKit-1V6l6ObeCe49St33RHPzLF_P_c3o7aSDTKs0/edit#heading=h.7dhnp46ven0v)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
선생님이 짜주신 코드에서, 궁금증을 느껴 i.name을 oi.item.name으로 바꾸고 join oi.item i 부분을 지웠습니다만, 출력에는 전혀 지장이 없었는데 inner join 대신 join만 생겼습니다. 쿼리가 나가는 횟수도 동일한 것 같은데 혹시 i.name으로 굳이 해주신 이유가 있으신가요? oi.item.name으로 사용해도 될까요?
또한 같은 문맥으로 where oi.order.id in :orderIds부분을 " join oi.order oio where oi.order.id in :orderIds"이렇게 고쳐도 join문이 늘어날 뿐 문제가 없었습니다. 아무튼 i.name과 oi.item.name의 차이에 대해서 궁금합니다. 굳이 별 차이 없으면 item join문을 작성해주지 않는 것이 더 코드가 깔끔해 보여서요

답변 1

0

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

안녕하세요. 신동훈님

JPA 기본편 강의의 경로 표현식 부분을 참고해주세요^^

https://www.inflearn.com/course/ORM-JPA-Basic/lecture/21727?tab=curriculum

감사합니다.

신동훈님의 프로필 이미지
신동훈

작성한 질문수

질문하기