✔️ JPA는 다양한 쿼리 방법을 지원한다.
- JPQL (Java Persistence Query Language)
- JPA Criteria
- QueryDSL
- 네이티브 SQL
- JDBC API 직접 사용, MyBatis, SpringJdbcTemplate 함께 사용
지금까지는 조회시 아래와 같이 가장 단순한 조회 방법에 대해서 알아보았다.
- EntityManager.find()
- 객체 그래프 탐색 ( a.getB().getC() )
🤔 그런데 만약 나이가 18살 이상인 회원을 모두 검색하고 싶다면 ?
JPQL (Java Persistence Query Language)
- 애플리케이션에서 필요한 데이터만 DB에서 불러오려면, 결국 검색 조건이 포함된 SQL이 필요
- JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어 제공
- JPQL은 객체지향 쿼리 언어다. 따라서 테이블을 대상으로 쿼리하는 것이 아니라, 엔티티 객체를 대상으로 쿼리한다.
- SQL을 추상화해서 특정 데이터베이스 SQL에 의존하지 않는다.
- JPQL은 결국 SQL로 변환된다.
- SQL 과 문법 유사
- SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
- 근본적인 차이는 SQL 은 DB를 대상으로 하는 쿼리이고 JPQL 은 엔티티를 대상으로 하는 쿼리이다.
- SQL:
select * from member where username like '%kim%'
- JPQL:
select m from Member m where m.username like '%kim%'
- JPQL 에서 Member 는 테이블이 아닌 엔티티 객체
- JPQL 은 특정 데이터베이스의 SQL 문법에 의존하지 않는다.
- 우리가 작성한 JPQL 을 JPA 에서 SQL 문법에 맞게 자동으로 변환하고, 변환된 쿼리가 나가게 된다.
- 참고)
- 그런데 JPQL 쿼리는 사실상 코드에서 보면 문자열이다. 그렇게 되면, 동적 쿼리 작성에 어려움이 있다. 그래서 문자가 아닌 자바코드로 JPQL을 작성할 수 있도록 빌더 역할을 해주는 기능으로 JPA Criteria, QueryDSL 이 있다.
Criteria
- 문자가 아닌 자바코드로 JPQL을 작성할 수 있음
- JPQL 빌더 역할
- JPA 공식 기능
- 단점: 너무 복잡하고 실용성이 없다.
- 참고) Criteria 대신에 QueryDSL 사용 권장
QueryDSL
- 문자가 아닌 자바코드로 JPQL을 작성할 수 있음
- JPQL 빌더 역할
- 오픈소스 프로젝트
- 컴파일 시점에 문법 오류를 찾을 수 있음
- 동적쿼리 작성 편리함
- 단순하고 쉬움
- 실무 사용 권장
네이티브 SQL
- JPA가 제공하는 SQL을 직접 사용하는 기능
- JPQL로 해결할 수 없는 특정 데이터베이스에 의존적인 기능
- 예) 오라클 CONNECT BY, 특정 DB만 사용하는 SQL 힌트
JDBC 직접 사용, SpringJdbcTemplate 등
- JPA를 사용하면서 JDBC 커넥션을 직접 사용하거나, 스프링 JdbcTemplate, 마이바티스 등을 함께 사용 가능
- 실무 주의) 단 영속성 컨텍스트를 적절한 시점에 강제로 플러시 필요
- 예) JPA를 우회해서 SQL을 실행하기 직전에 영속성 컨텍스트 수동 플러시
강의를 듣고 정리한 글입니다. 코드와 그림 등의 출처는 김영한 강사님께 있습니다.