강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

Cera님의 프로필 이미지
Cera

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

모든 종류의 상품을 한번에 DTO로 출력할 수 있을까요?

해결된 질문

작성

·

342

0

안녕하세요,

다름이 아니라 강의를 마치고 단일 테이블 전략으로 구성된 상품목록을 한번에 DTO로 만들어서 출력해보고 싶은데 

이것이 가능한 방법일까요?

 

테스트의 구성은 아래와 같습니다.

@Test
    public void dtoMappingTest() throws Exception{
        //given
        Book book = createBook("JAVA PERSISTENCE API", 10000, 10, "AUTHOR", "ISBN");
        Movie movie = createMovie("MOVIE", 10000, 3, "ACTOR", "DIRECTOR");
        Album album = createAlbum("ALBUM", 5000, 20, "ARTIST", "INFO");

        //when
        List<Item> list = itemRepository.findAll();

        //then

        // 책, 영화, 앨범 각각의 정보를 포함한 DTO를 한 리스트에?

    }

이렇게 전체 아이템 리스트를 받아 온 다음

아래와 같은 DTO 클래스에 해당 상품 종류에 맞는 정보를 매핑해서 하나의 리스트 형태로 리턴하는것이 가능할까요?

 

@Getter
@Setter
@Builder
@JsonInclude(Include.NON_EMPTY)
public class ItemDto {

    private Long id;

    private String name;

    private int price;

    private int stockQuantity;

    private List<Category> categories;

    private String artist;

    private String etc;

    private String director;

    private String actor;

    private String author;

    private String isbn;

}

 

 

시간이 늦어서 아직 구현은 안 해보았지만 제가 생각한 해결책은

Item 클래스에 DTO를 생성해주는 추상 메소드를 생성하고

각각의 상품 종류별 클래스에 그 추상 메소드를 직접 구현하는 방법입니다.

 

이 방법이 현실성이 있는지 아니면 다른 방법이 있는 것인지 아예 불가능한 이야기인지 정말 궁금합니다.

감사합니다.

 

답변 1

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. Cera님

조회시 타입이 확정되기 때문에 어려울 것 같아요.

네이티브 SQL을 사용해주세요.

감사합니다.

Cera님의 프로필 이미지
Cera

작성한 질문수

질문하기