• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

프로젝션 'new 명령어로 조회' 질문 입니다.

24.05.08 19:59 작성 조회수 55

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

안녕하세요? 프로젝션 쿼리에 new 명령어 관련 헷갈리는 부분이 있어서 질문 드립니다!

try{

    Member member = new Member();
    member.setUsername("member1");
    member.setAge(10);
    em.persist(member);

    em.flush();
    em.clear();

    List<MemberDTO> result = em.createQuery("SELECT new jpql.MemberDTO(m.username, m.age) FROM Member m", MemberDTO.class)
            .getResultList();
    MemberDTO memberDTO = result.get(0);
    System.out.println("memberDTO = " + memberDTO.getAge());
    System.out.println("memberDTO = " + memberDTO.getUsername());


    tx.commit();
}

위와 같은 쿼리를 실행하게 되면 상위에서 생성한 member 객체에 있는 값을 result 로 복사하고 result 값을 memberDTO List의 인덱스 0으로 들어 간 값을 조회하라는 뜻이 맞는건가요..?

수업듣다가 제가 이해한게 맞는지 헷갈려서 질문 드립니다..

답변 부탁드립니다!!

감사합니다.

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.05.08

안녕하세요, 인프런 AI 인턴입니다.

질문하신 “프로젝션 ‘new 명령어로 조회’“와 관련하여 이해하고 계신 부분이 맞습니다. 사용하신 new 명령어를 사용하는 JPQL 쿼리는 조회된 데이터를 기반으로 MemberDTO 타입의 객체를 직접 생성하여 리스트로 반환합니다. 즉, Member 엔티티로부터 조회된 usernameage를 사용해 MemberDTO의 새 인스턴스를 생성하고, 이 객체가 리스트에 추가됩니다. 이 리스트의 첫 번째 인덱스에 위치한 MemberDTO 객체를 가져와서 getAge()getUsername() 메서드를 호출함으로써 값을 출력합니다.

이와 비슷한 상황에 대한 기존 답변이 있어 보다 자세한 이해를 돕고자 링크를 제공드립니다:
- dto 에 대해서 질문 드립니다.

위 질문에서는 DTO (Data Transfer Object)의 생성과 조회에 대해 new 연산자를 사용하는 JPQL 쿼리 예제를 다루고 있으며, 해당 과정에서 DTO를 조회할 때 new 오퍼레이션을 사용하는 방법에 대한 설명이 포함되어 있습니다. new 명령어 사용법이 정확히 이해하신 것과 일치한다는 점을 확인하실 수 있습니다.

정리하자면, 질문하신 내용과 관련하여 new 명령어는 JPQL에서 복잡한 조회 결과를 사용자 정의 타입으로 바로 매핑할 때 사용되며, 이를 통해 얻은 결과 객체들을 리스트 형태로 받아 사용할 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.