inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

복잡하고 join이 많은 쿼리에 대해 질문이 있습니다.

422

작성자 없음

작성한 질문수 0

0

안녕하세요 영한님

강의도 듣고, 책도 잘읽고 있습니다.

요즘엔 책을 주로 읽고 있네요 ㅎㅎ

다름이 아니라 제가 질문이 있습니다.

제가 jpa를 사용하는 개인 프로젝트를 진행중이고, 영한님 책을 보면서 많은 도움을 받고있습니다.

그런데 책에는 주로 join이 많아야 한번정도 있는 예제들이 많은데,

제가 사용하는 쿼리는 join을 4번씩이나 하고, 그렇게 해서 나온 결과 행들중 랜덤으로 하나의 row를 추출해야하는 형태라 order by random() limit 1 이런식의 조건을 주려했습니다.

다소 조인이 많이들어간 쿼리인데

spring data jpa 의 @query를 사용하려다보니 쿼리가 너무 길어서 뭔가 하드코딩하는 느낌도 들고, @query에서는 rand를 지원하지 않더군요... 

이런경우에는 주로 querydsl을 사용하나요? 다른 질문을 보니 creteria 는 사용하지 않는게 좋다는 의견이있으셔서 질문드립니다. 아니면 단순히 jparepository를 구현한 repository 인터페이스를 이용해서도 해결이 가능할까요?ㅠㅠ

JPA java

답변 1

0

김영한

안녕하세요. gr gsad님

JPA가 제공하는 JPQL은 모든 SQL 문법을 다 제공하지는 않습니다.

Querydsl이나 creteria도 JPQL 문법을 코드로 작성하는 것입니다.

일반적으로 90% 이상은 JPQL로 해결이 가능한데, 복잡한 통계성 쿼리나 특정 데이터베이스에 너무 종속적인 경우에는 네이티브 쿼리 또는 JdbcTemplate과 같이 사용해야 합니다.

강의 뒷 부분에서 객체지향쿼리언어인 JPQL을 학습하시면 어떤 부분에서 JPQL을 사용해야 할지 어떤 부분에서 네이티브 쿼리를 사용해야할지 이해가 되실거에요.

감사합니다.

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

0

45

2

inheritance startegy 선택시 고려사항

0

28

1

Entity 동등성 비교

0

29

1

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

0

54

1

H2데이터베이스 파일 생성

0

62

2

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

0

61

2

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

0

59

1

JPQL 메소드와 락

0

58

1

Delivery @OneToOne

0

64

1

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

0

98

2

UnsupportedOperationException 발생

0

89

3

H2 Database 연결이 안됩니다.

0

98

2

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

0

88

2

h2데이터베이스 실행오류

0

110

2

persistence.xml

0

114

2

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

0

84

1

영속성 컨텍스트

0

70

1

JPA 프록시

0

100

1

Native Query와 MyBatis

0

74

1

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

0

95

1

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

0

122

3

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

0

97

3

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

0

110

2

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

0

149

1