인프런 커뮤니티 질문&답변

김재연님의 프로필 이미지
김재연

작성한 질문수

스프링 MVC 2편 - 백엔드 웹 개발 활용 기술

게시글 구현에 대한 질문

작성

·

202

0

현재 게시글과 댓글에 대한 프로젝트를 만들고 있습니다.

만들던 도중에 질문이 생겨 글을 올리게 되었습니다.

 

게시글과 댓글은 각각 다른 어그리거트인거 같은데,

게시글 상세페이지를 보여주는 서비스에서

다른 어그리거트인 댓글repository를 di해서 사용해도 문제가 없나요?

 

그리고

게시글 댓글의 연관관계를 양방향으로 하지 않고

단방향으로 manyToOne만 해놓았습니다.

게시글 상세페이지 서비스에서는 댓글repository를 활용하여

댓글 10개를 가져옵니다. (manyToOne로 엮인 게시글은 fetch join)

이 댓글 10개를 게시글상세responseDto로 넘겨서 dto로 변환합니다.

이 방식도 문제가 없을까요

 

 

패키지 구조는 이렇습니다.

controller

- post

- comment

service

- post (게시글 상세 페이지를 보여주는 서비스 위치)

- comment

domain

- post

- comment

repository

- post

- comment (댓글repository 위치)

답변 1

1

안녕하세요, 인프런 AI 인턴이에요.

게시글과 댓글이 서로 다른 어그리거트인 경우, 댓글repository를 게시글 상세페이지 서비스에서 DI하여 사용하는 것은 일반적으로 문제가 되지 않습니다. 어그리거트 간의 커뮤니케이션이 필요한 경우에는 DI를 통해 다른 어그리거트의 repository를 사용하는 것이 좋은 방법입니다.

댓글의 연관관계를 양방향으로 하지 않고 단방향으로 manyToOne만 설정한 것도 일반적으로 문제가 되지 않습니다. 단방향 연관관계를 사용할 때는 조회할 때 추가적인 쿼리가 발생할 수 있으므로 주의해야 합니다. 하지만 여러 댓글을 함께 조회할 때 fetch join을 사용하면 추가 쿼리 없이 한 번에 조회할 수 있기 때문에 성능상으로 큰 문제는 없을 것입니다.

패키지 구조는 일반적으로 좋은 구조로 보입니다. 컨트롤러, 서비스, 도메인, 리포지토리 각각의 역할에 맞도록 분리되어 있는 것 같아요.

더 자세한 내용이 필요하거나 다른 질문이 있으시면 언제든지 물어보세요. 좋은 프로젝트 진행하시길 바라요!

김재연님의 프로필 이미지
김재연

작성한 질문수

질문하기