• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

스칼라 타입 프로젝션에서 이해가 안가는게 한가지 있습니다!

22.11.04 00:15 작성 조회수 240

1

안녕하세요 스칼라 타입에서 질문이 있습니다!!!
처음에 엔티티, 임베디드 타입, 스칼라 프로젝션을 다 같이 설명하실때 작성하셨던

em.createQuery("select m.username, m.age from Member m")

이 코드에서 실행하셨을때 스칼라 타입이 딱히 문제 없이 실행된 것 같은데 이건 조회를 하는 코드가 아닌가요....?

다른 엔티티나 임베디드 타입은 그냥 저런 식으로 작성해서 조회가 된다고 하셨고 실행하셨을 때, 문제가 없는 것처럼 말씀을 하셨고

스칼라 타입도 처음에 저렇게 실행을 하셨을 때, 결과 창이 비슷하게 나와서 저는 저게 조회하는 코드인 줄 알았는데 뒤에 바로 고민거리가 생긴다고 하시고
DTO을 생성한 뒤, new operation을 사용해서 코드를 작성하셔서 이렇게 조회를 해야된다고 하셨는데

Q1. 그럼 제가 위에서 적은 조회하는 코드라고 생각했던 것은 왜 크게 오류가 안나고 실행이 된건가요....?

Q2. 그리고 MemberDTO자리에 그냥 Member 엔티티로 대신 사용해도 문제 없이 실행이 되던데 DTO를 사용하는 이유는 중요 역할을 하는 엔티티를 반환하는 것이 설계상 안 좋아서 DTO를 따로 만드신 건가요???

답변 1

답변을 작성해보세요.

3

David님의 프로필

David

2022.11.04

안녕하세요. 지호님, 공식 서포터즈 David입니다.

  1. 스칼라 프로젝션에서 고민거리가 생긴다는 말은 조회는 되는데, 어떻게 결과 값을 반환 받을지에 대한 것입니다. 오류가 발생하는 게 아닙니다.

  2. 여러가지 이유가 있는데 그 중 하나는 엔티티의 경우 조회 후 변경감지가 동작하게 되지만 DTO는 그렇지 않습니다. 또 다른 하나는 조인된 쿼리에서 멤버 엔티티에 없는 필드 데이터를 가져오려면 필요한 값들만 받을 수 있도록 DTO를 만들어주는 것입니다.

감사합니다.

지호님의 프로필

지호

질문자

2022.11.04

아하! 기초적인 부분일 수 있는데도 항상 친절하게 답해주셔서 너무 감사드립니다 ㅠㅠ