강의

멘토링

로드맵

Inflearn brand logo image

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

작성자 없음

작성자 정보가 삭제된 글입니다.

스프링부트로 직접 만들면서 배우는 대규모 시스템 설계 - 게시판

댓글 최대 2 depth - CUD API 구현

댓글 최대 2depth - CUD API 구현에서 질문 있습니다.

해결된 질문

작성

·

67

·

수정됨

0

안녕하세요 선생님 좋은 강의 해주셔서 감사합니다.

댓글 create 구현에서 findParent() 함수를 구현할때,

.filter(Comment::isRoot)

이런 코드가 있는데, 애초에 parentCommentId 에 root 댓글이 아닌 댓글의 ID가 존재하면 안되는 것 아닌가요 ?


존재하면 안되는 경우를 filter 로 걸러주는 것 같아서 필요한 코드인지 의문이 들어 질문 남깁니다.

답변 2

1

쿠케님의 프로필 이미지
쿠케
지식공유자

태우님, 안녕하세요!

 

request.parentCommentId는 클라이언트한테 전달받는 값입니다.

클라이언트가 parentCommentId에 1뎁스 댓글 ID를 전달한다고 기대할 뿐이지,

해당 값이 반드시 부모 댓글 ID라는 것을 보장할 수 없습니다.

parentCommentId에 2뎁스 댓글 ID를 전달하면, 신규 생성 건은 3뎁스 댓글로 만들어질 수 있으므로 최대 2뎁스 규칙에 대한 보장이 깨지게 되는 것입니다.

이러한 검증을 위한 방어 로직이라고 봐주시면 될 것 같네요!

0

안녕하세요, 인프런 AI 인턴입니다. 김태우님.

질문해주신 댓글 작성 관련 구현 사항은 대규모 시스템에서의 댓글 트리 구조와 데이터 일관성 유지에 관한 것입니다. findParent() 함수에서 filter(Comment::isRoot) 를 사용하는 이유는 다음과 같습니다.

findParent() 함수의 의도와 동작

  1. 데이터 검증 및 보호:

    • filter(Comment::isRoot) 는 부모 댓글이 반드시 루트 댓글이어야 한다는 조건을 강제합니다. 이 코드를 통해 root 댓글이 아닌 경우를 필터링하여, 시스템 내에서 논리적인 일관성을 유지할 수 있습니다.
  2. 잘못된 데이터 접근 방지:

    • 실수로 부모 댓글을 지정하는 과정에서 잘못된 ID(루트 댓글이 아닌)를 지정할 수 있습니다. 이러한 경우를 미리 방지하여 데이터베이스에 잘못된 상태가 저장되지 않도록 보장합니다.
  3. 시스템 안정성 및 유지보수성 확보:

    • 잘못된 데이터가 입력되었을 경우 시스템에 발생할 수 있는 잠재적인 오류를 예방하고, 정확한 트리 구조를 유지하기 위해 이러한 필터링 과정을 추가합니다. 이를 통해 코드의 안정성과 유지 보수성을 확보할 수 있습니다.

이런 체크는 비즈니스 로직이 변경되거나 향후 최적화 과정에서도 데이터의 일관성을 보장하는 데 중요한 역할을 합니다.

관련된 유사한 질문의 사례를 참고하고자 한다면 아래의 URL을 확인하시면 좋을 것 같습니다:
- 댓글 트리의 일관성 및 데이터 검증 방법 (게시글 제목)

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

작성자 없음

작성자 정보가 삭제된 글입니다.

질문하기