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();
}
제이슨 결과
Json 결과에 대해
제가 궁금한것은 홍길동이라는 사람의 팀네임을 뽑기위해
teamMembers -> teamName 으로 나오는것은 비효율 적이라 생각합니다
즉 제가 원하는 결과는
혹시 방법이 있나요?
Answer 1
0
안녕하세요, 김진영 님. 공식 서포터즈 codesweaver 입니다.
.
예로 들어주신 경우는 홍길동이 '길동1팀' 한개만 소속되어 있을경우에는 더 효율적인 방법입니다. 그러나 현재 설계가 한 사람이 여러개의 팀에 소속될 수 있음을 전제하고 있습니다. 그래서 소속팀은 리스트 형태로 반환하는것이 적합합니다.
만약 의도하신바가 여러개의 팀에 소속되어있다 하더라도 String 하나로 반환되기를 원하는것이라면 (예: "teamName" : "길동1팀, 길동2팀") MemberDto teamMembers 필드를 String으로변경, 생성자 부분에서 teamMembers 를 처리하는 람다 부분을 리스트를 반환하는 것이 아닌 콤마를 기준으로 문자열로 합치도록 수정해주시면 됩니다.
..
감사합니다.