[ 김영한 자바 ORM 표준 JPA 프로그래밍 - 기본편 #8 ] JPQL 소개

김수호·2024년 5월 10일
0
post-thumbnail

✔️ 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을 실행하기 직전에 영속성 컨텍스트 수동 플러시

강의를 듣고 정리한 글입니다. 코드와 그림 등의 출처는 김영한 강사님께 있습니다.

profile
현실에서 한 발자국

0개의 댓글