인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

Inflearn Community Q&A

Ahrisan's profile image
Ahrisan

asked

Real-world! Spring Boot and JPA Utilization 2 - API Development and Performance Optimization

Order Lookup V3: Converting Entities to DTOs - Fetch Join Optimization

다대다 컬럼조회 질문

Written on

·

192

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팀",
]
}

혹시 방법이 있나요?

 

springJPAspring-bootjava

Answer 1

0

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

 

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

..
감사합니다.

Ahrisan's profile image
Ahrisan

asked

Ask a question