inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

주문 조회 V3: 엔티티를 DTO로 변환 - 페치 조인 최적화

다대다 컬럼조회 질문

213

Ahrisan

작성한 질문수 25

0

해당강의까지 진행하고 실습해보고 있습니다.

 

Member <-> Team 이 다대다 관계여서 
이관계를 풀기위해 
Member -< TeamMember >- Team
      1           :                N               :       1. 

로 풀어줬습니다.

 

teamId 를 url로 받아서 해당 팀에 소속된 멤버를 조회하고 싶습니다.

 

ApiController

@GetMapping("/members/{teamId}")
public List<MemberDto> findByTeamMembers(
@PathVariable Long teamId
) {
List<Member> members = memberService.findByTeamMembers(teamId);
List<MemberDto> result = members.stream()
.map(m -> new MemberDto(m))
.collect(Collectors.toList());
return result;
}


MemberDTO & TeamMemberDto

@Data
public class MemberDto {
private Long memberId;
private String name;
private MemberStatus status;
private String avatar;
private List<TeamMemberDto> teamMembers;

public MemberDto(Member member) {
memberId = member.getId();
name = member.getName();
status = member.getStatus();
avatar = member.getAvatar();
teamMembers = member.getTeamMembers()
.stream().map(teamMember -> new TeamMemberDto(teamMember))
.collect(Collectors.toList());
}

@Data
static class TeamMemberDto {
private String teamName;
private Long hostId;

public TeamMemberDto(TeamMember teamMember) {
teamName = teamMember.getTeam().getName();
hostId = teamMember.getTeam().getId();
}
}
}


Repository

public List<Member> findByTeamMembers(Long teamId) {
return em.createQuery("select distinct m from Member m" +
" join fetch m.teamMembers tm" +
" join fetch tm.team t" +
" where t.id = :teamId",Member.class)
.setParameter("teamId", teamId)
.getResultList();
}



제이슨 결과

{
"memberId": 4,
"name": "홍길동",
"status": "LOGIN",
"avatar": null,
"teamMembers": [
{
"teamName": "길동1팀",
}
]
}

Json 결과에 대해

제가 궁금한것은 홍길동이라는 사람의 팀네임을 뽑기위해 
teamMembers -> teamName 으로 나오는것은 비효율 적이라 생각합니다

즉 제가 원하는 결과는 

{
"memberId": 4,
"name": "홍길동",
"status": "LOGIN",
"avatar": null,
"teamName": "길동1팀",
]
}

혹시 방법이 있나요?

 

spring JPA spring-boot java

답변 1

0

나무늘보

안녕하세요, 김진영 님. 공식 서포터즈 codesweaver 입니다.
.
예로 들어주신 경우는 홍길동이 '길동1팀' 한개만 소속되어 있을경우에는 더 효율적인 방법입니다. 
그러나 현재 설계가 한 사람이 여러개의 팀에 소속될 수 있음을 전제하고 있습니다. 그래서 소속팀은 리스트 형태로 반환하는것이 적합합니다.

 

만약 의도하신바가 여러개의 팀에 소속되어있다 하더라도 String 하나로 반환되기를 원하는것이라면 (예: "teamName" : "길동1팀, 길동2팀")  MemberDto teamMembers 필드를 String으로변경, 생성자 부분에서 teamMembers 를 처리하는 람다 부분을 리스트를 반환하는 것이 아닌 콤마를 기준으로 문자열로 합치도록 수정해주시면 됩니다. 

..
감사합니다.

강의 관련 외 질문입니다.

0

68

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

0

92

1

BeanCreationException

0

91

3

Update 후 UpdateMemberResponse 매핑할 때

0

50

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

101

2

페이징 + 검색조건 관련해서 질문드립니다.

0

70

1

Query Dsl Q파일 질문입니다.

0

84

1

루트 쿼리라는것은

0

60

1

메서드를 분리하는 기준

0

65

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

111

3

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

0

86

2

fetch join과 영속화와 OSIV의 관계

0

87

2

Distinct 사용 전 결과에 대한 의문

0

117

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

59

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

78

2

dto 필드 속 엔티티 여부

0

60

1

뷰템플릿 사용 시

0

77

2

Result 클래스 관련 질문

0

56

1

@PostConstruct 프록시 관련 질문드립니다

0

86

1

DTO 대신 Form 사용은 안되나요?

0

138

1

OSIV ON 상태일 때

0

96

1

fetch join VS fetch join 페이징 궁금증

0

187

2

양방향 연관관계 알아보는 법?

0

106

1

16강 17강 간단 정리 이게 맞을까요 ?

0

166

2