inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

서브쿼리에서 사용한 ALL에 대한 궁금증이있습니다.

225

티벳로보

작성한 질문수 48

0

제가 작성한 JPQL 입니다

"select o 
from Order o 
where o.orderAmount > ( select x.stockAmount from o.product x)"

강사님이 작성한 JPQL 입니다.

"select o 
from Order o 
where o.orderAmount > ALL ( select x.stockAmount from o.product x)"

// 전체 상품 각각의 재고보다 주문량이 많은 주문들

이 조회를 하기 위해서 JPQL을 작성했는데요

 

첫번째 코드나 두번째 코드나 결과는 같다고 생각이 들었어요

두 코드 모두

select
                p2_0.stockAmount 
            from
                Product p2_0 
            where
                p2_0.id=o1_0.product_id

이 코드가 동작하게 되는데

Product와 Order는 1:M인 관계로 stockAmount는 (1x1)이 나오게 되는데

ALL을 사용할 이유가 있나해서 궁금합니다.

java jpa

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

서브쿼리에서 사용되는 ALL 키워드는 다음과 같은 의미를 가집니다. ALL 연산자는 서브쿼리에서 반환한 값과 일치하는 모든 값을 검사하는데 사용됩니다. 즉, 서브쿼리 결과의 각 값과 조건을 비교해서 모든 값을 만족하는 경우에만 참으로 인식됩니다.

두번째 JPQL 코드에서 ALL 키워드가 사용된 이유는 “주문량이 전체 상품의 각각의 재고보다 많은 주문들”을 조회하기 위해서입니다. 즉, 주문량이 모든 상품의 각각의 재고보다 많은 주문들을 선택하고자 할 때 ALL을 사용할 수 있습니다.

첫번째 JPQL 코드와 두번째 JPQL 코드는 결과가 같게 나올 수 있지만, ALL을 사용한 경우에는 모든 상품의 재고를 비교하는 것이기 때문에 더 적합한 표현이 될 수 있습니다.

그러나 실제로는 성능상의 차이가 있을 수 있으므로, 실제 상황에서는 두 가지 표현을 비교해보고 성능 향상을 위해 적절한 방법을 선택하는 것이 좋습니다.

마지막으로 주의하실 점은 ALL 연산자는 서브쿼리의 결과가 비어있는 경우에는 항상 거짓을 반환한다는 것입니다.

더 궁금한 점이 있으시면 언제든지 물어보세요. 좋은 하루 되세요!

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

22

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

18

1

실무 조언 관련 질문입니다.

0

46

1

H2데이터베이스 파일 생성

0

56

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

52

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

51

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

93

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

92

2

연관관계 매핑 질문드립니다.

0

85

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

80

1

영속성 컨텍스트

0

65

1

JPA 프록시

0

94

1

Native Query와 MyBatis

0

68

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

85

1

임베디드 타입 예시 코드 관련 질문

0

114

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

94

3

인텔리제이 패키지 커서 단축키 질문

0

108

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

143

1