• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

virtual에 대해 질문이있습니다.

21.10.05 10:28 작성 조회수 136

2

좋은 강의 감사합니다. 

virtual 을 써야할때와 , user처럼 관계를 줄때를 

어떻게 구분하면 되는건가요?? 

이부분에 대한 설명이 없어서 언제/왜 써야하는지를 알고싶습니다.

답변 1

답변을 작성해보세요.

1

populate는 문서에 내장되어 있는 자식 문서들의 id(rdb에서의 primary key)들을 가지고 JOIN을 하는거에요.

Blog 문서에는 userId가 내장되어 있고

User 문서에는 blogIds들이 내장되어 있지 않다.

이런 데이터 구조일 때로 설명을 드리면. Blog에는 userId가 있기 때문에 populate로 블로그의 유저를 바로 불러올 수 있어요.

하지만 반대로 유저 문서를 불러오고 해당 유저의 모든 블로그들을 불러오고 싶다면 같은 populate 방법을 사용할 수가 없죠. 유저 문서에 blogIds가 저장되어 있지 않으니깐요. 만약 user에도 blog id들을 배열로 저장했다면 동일하게 populate를 적용할 수 있습니다.

이 때 사용할 수 있는 방법이 virtual populate에요. blog에는 userId가 저장되어 있으니깐요. 관계형디비에서 foreign key로 쿼리날리는것과 동일한 방법이라고 보면 되요. populate는 부모 문서가 자식 문서들의 primary key들을 가지고 있는 경우였고요.