상속관계에서 Item 대신 자식엔티티를 사용하는 경우 질문입니다.
547
작성한 질문수 3
안녕하세요 강사님
먼저 정말 좋은 강의 정말 정말 감사합니다. 덕분에 회사에서 일할맛이 납니다ㅠㅠ
강의를 다듣고 혼자서 복습해보다가 문득 생각나서 질문드립니다.
혹시 먼저 질문한 사람이 있을까해서 찾아봤는데 없어서 질문드립니다.
Single Table 상속관계에서 강의에서는 부모 엔티티인 Item를 바로 가져오셨는데,
만약 자식인 Book, Album 등을 Dto로 조회할 때는 자식 타입으로 다운 캐스팅해야 되는 것인가요?
Item 객체에서는 Album의 artist, etc를 가져올 방법이 없는 것 같아서요
class AlbumDto {
private String artist;
private String etc;
setArtist(Item item) {
this.artist = (Album) item.getArtist();
}
}
아니면 DType을 조건으로 해서 직접 Album, Book을 직접 가져오는지 궁금합니다.
둘다 아니라면 각 자식 엔티티 별로 Repository를 생성하여 데이터를 반환하는지 궁금합니다.
마지막으로 데이터베이스의 Item들을 모두 가져오고 싶으면 각 행의 결과에 따라 모두 자식 엔티티로 형 변환을 해줘야 되는지 궁금합니다.
답변 1
0
안녕하세요 Byeonggil Park님
JPA에서 조회할 때 부터 해당 타입을 지정해서 조회하면 됩니다.
물론 이 경우 모든 아이템을 다 가져오는 것이 안되고, 해당 타입만 한정해서 조회하기 때문에 전체를 다 가져오려면 Item 타입으로 지정해서 조회하고, 형변환을 해주어야 합니다. 실제 JPA에서 조회할 때 Book으로 조회하도록 테스트 해보시고, 실행되는 쿼리를 보시면 바로 감이 오실거에요^^
감사합니다.
강의 관련 외 질문입니다.
0
62
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
0
85
1
BeanCreationException
0
86
3
Update 후 UpdateMemberResponse 매핑할 때
0
46
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
96
2
페이징 + 검색조건 관련해서 질문드립니다.
0
70
1
Query Dsl Q파일 질문입니다.
0
81
1
루트 쿼리라는것은
0
58
1
메서드를 분리하는 기준
0
61
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
108
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
83
2
fetch join과 영속화와 OSIV의 관계
0
83
2
Distinct 사용 전 결과에 대한 의문
0
112
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
55
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
77
2
dto 필드 속 엔티티 여부
0
58
1
뷰템플릿 사용 시
0
76
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
85
1
DTO 대신 Form 사용은 안되나요?
0
133
1
OSIV ON 상태일 때
0
94
1
fetch join VS fetch join 페이징 궁금증
0
179
2
양방향 연관관계 알아보는 법?
0
103
1
16강 17강 간단 정리 이게 맞을까요 ?
0
161
2





