작성자 없음
작성자 정보가 삭제된 글입니다.
작성
·
352
0
안녕하세요 영한님
강의도 듣고, 책도 잘읽고 있습니다.
요즘엔 책을 주로 읽고 있네요 ㅎㅎ
다름이 아니라 제가 질문이 있습니다.
제가 jpa를 사용하는 개인 프로젝트를 진행중이고, 영한님 책을 보면서 많은 도움을 받고있습니다.
그런데 책에는 주로 join이 많아야 한번정도 있는 예제들이 많은데,
제가 사용하는 쿼리는 join을 4번씩이나 하고, 그렇게 해서 나온 결과 행들중 랜덤으로 하나의 row를 추출해야하는 형태라 order by random() limit 1 이런식의 조건을 주려했습니다.
다소 조인이 많이들어간 쿼리인데
spring data jpa 의 @query를 사용하려다보니 쿼리가 너무 길어서 뭔가 하드코딩하는 느낌도 들고, @query에서는 rand를 지원하지 않더군요...
이런경우에는 주로 querydsl을 사용하나요? 다른 질문을 보니 creteria 는 사용하지 않는게 좋다는 의견이있으셔서 질문드립니다. 아니면 단순히 jparepository를 구현한 repository 인터페이스를 이용해서도 해결이 가능할까요?ㅠㅠ
답변 1
0
안녕하세요. gr gsad님
JPA가 제공하는 JPQL은 모든 SQL 문법을 다 제공하지는 않습니다.
Querydsl이나 creteria도 JPQL 문법을 코드로 작성하는 것입니다.
일반적으로 90% 이상은 JPQL로 해결이 가능한데, 복잡한 통계성 쿼리나 특정 데이터베이스에 너무 종속적인 경우에는 네이티브 쿼리 또는 JdbcTemplate과 같이 사용해야 합니다.
강의 뒷 부분에서 객체지향쿼리언어인 JPQL을 학습하시면 어떤 부분에서 JPQL을 사용해야 할지 어떤 부분에서 네이티브 쿼리를 사용해야할지 이해가 되실거에요.
감사합니다.