inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

mongoDB 기초부터 실무까지(feat. Node.js)

Nesting 성능 테스트

Nesting schema 질문요???

214

신론

작성한 질문수 3

2

안녕하세요. 저번 질문의 답변 감사합니다.  각각 방법을 비교하여 펴포먼스 테스트로 많은 이해가 되었습니다.  그런데 궁금한게 혹시 그럼 예를 들면 blogSchema에 commentSchema를 nesting 하여 퍼포몬스를 증가 시켰는데 어찌보면 제일 좋은 방법인데 그럼 blogschema에 user 키에도 userSchema를 네스팅 하면 안되나요?   user 키에는 Type.ObjectId만 설정 되오있는데 그냥 이것도 comment 처럼 user: [userScehma] 로 하면 되는지 궁금합니다.

mongoose 데이터 엔지니어링 mongodb nodejs DBMS/RDBMS javascript rest-api aws

답변 1

0

김시훈 (도도소프트)

신론님 안녕하세요 :)

두 방법에 대한 차이를 자세히 설명 못했었나보네요.

const BlogSchema = new Schema(
{
title: { type: String, required: true },
content: { type: String, required: true },
islive: { type: Boolean, required: true, default: false },
user: {
_id: { type: Types.ObjectId, required: true, ref: "user" },
username: { type: String, required: true },
name: {
first: { type: String, required: true },
last: { type: String, required: true },
},
},
commentsCount: { type: Number, default: 0, required: true },
comments: [CommentSchema],
},
{ timestamps: true }
);

위와 아래는 둘다 user를 blog에 내장하는 모델이에요. MongoDB Compass에서 데에터를 확인해보시면 user 정보가 내장되었음을 보실 수 있어요. 

const BlogSchema = new Schema(
{
title: { type: String, required: true },
content: { type: String, required: true },
islive: { type: Boolean, required: true, default: false },
user: { type: UserSchema, required: true },
commentsCount: { type: Number, default: 0, required: true },
comments: [CommentSchema],
},
{ timestamps: true }
);

따라서 둘 다 퍼포먼스가 동일하게 좋죠. 아래처럼 하면 user의 필드들을 다시 선언할 필요가 없어서 코드가 간결해지는 장점이 있어요. 이 경우 또한 아래 코드처럼 UserSchema를 대입해도 문제가 되지 않아요. 다만 자식문서의 필드들을 부분적으로 내장하고 싶으면 첫번째 방법으로 해야합니다. 

이 강의에서는 "권한(인증)"을 다루지 않지만 대표적인 예시로 user의 개인정보나 hash처리된 비밀번호가 있겠네요.  실제 운영하는 서비스를 만들었다면 UserSchema에 hashPassword 혹은 외부에 노출 되지 말아야할 개인정보들이 있을 수 있겠죠. 그러면 UserSchema전체가 아니라 부분적으로 내장해야하구요.

option usecreateindex is not supported 오류 나면은

0

146

1

Schemaless 특성을 재생시 검은화면이 나와요

0

240

1

user 내장 시 ref 필드 필요성

0

239

1

await 관련해서 질문드릴게 있습니다!!

0

292

2

섹션6의 3번째 강의 faker파일이 어디있나요?

0

308

1

$elemMatch 질문이 있습니다.

0

245

1

DB 업데이트에 실패했을 상황에서 대처는 어떻게 할 수 있나요.

2

766

2

블로그에 user 데이터를 추가하는 방법에 대해서

0

237

1

blog 데이터 생성시 user 관련 오류

0

351

1

age 예외 처리를 별도로 하신 이유가 궁금합니다.

2

301

2

delete 메소드가 많은 이유가 궁금합니다.

0

181

1

unique validation 처리

0

296

1

updateMany에서 user._id를 못찾는 상황

1

396

1

find() 가 리턴하는 instance member

1

431

3

몽고 db를 백업방법을 부탁합니다.

0

603

1

인덱스 생성시점

0

712

1

$pull 문법에 대한 질문

0

359

1

comment의 id가 생성되는 시점

1

301

1

리팩토링 강의에서 라우터 리팩토링 전개연산자(...)

1

315

1

session.abortTransaction()에 대한 실제 예시 문의

0

287

1

섹션9 Computed Fields 강의에서, 다음 강의 가기 전 빠진부분

-1

407

1

faker 패키지 취약성 이슈

1

486

1

라우터 리팩토링

0

342

1

섹션4 진행중, mongoose 질문

0

310

1