다대다 컬럼조회 질문
213
작성한 질문수 25
해당강의까지 진행하고 실습해보고 있습니다.
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 으로 나오는것은 비효율 적이라 생각합니다
즉 제가 원하는 결과는
혹시 방법이 있나요?
답변 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





