JPQL 프로젝션

InOut·2023년 7월 21일

JPA

목록 보기
2/4

프로젝션

  • SELECT 절에 조회할 대상을 지정하는것
  • 프로젝션 대상 : 엔티티, 임베디드 타입, 스칼라 타입(숫자, 문자 등 기본 데이터 타입
  • SELECT m FROM Member m -> 엔티티 프로젝션
  • SELECT m.team FROM Member m -> 엔티티 프로젝션
  • SELECT m.address FROM Member m -> 임베디드 타입 프로젝션
  • SELECT m.username, m.age FROM Member m -> 스칼라 타입 프로젝션
  • DISTINCT 로 중복 제거

프로젝션 - 여러 값 조회

  • SELECT m.username, m.age FROM Member m
  1. Query 타입으로 조회
  2. Object[] 타입으로 조회
  3. new 명령어로 조회
    • 단순 값을 DTO로 바로 조회
      SELECT new jpql.MemberDTO(m.username, m.age) FROM Member m
    • 패키지 명을 포함한 전체 클래스 명 입력
    • 순서와 타입이 일치하는 생성자 필요




1. Query 타입

2. Object[] 타입

3. new생성자 이용

이 글은 김영한님의 JPA 강의를 듣고 정리한 내용입니다.

profile
개발새발

0개의 댓글