inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

MongoDB 데이터 구조에 대해 질문 있습니다.

217

김현종

작성한 질문수 5

1

안녕하세요. 강의를 듣고 궁금한 점이 생겨서 여쭤봅니다.

이러한 모양의 테이블이나 이보다 더 복잡한 테이블의 셀안의 값을 표현하고자 할때의 질문이 있습니다.

저러한 모양의 스키마를 짜서 내장이나 populate하는 것은 document가 길어질 수록 셀에 표현될 값을 탐색하는데 어려움이 있습니다.

그렇다고 각 셀마다 저기에 맞는 값을 호출해서 표현하기에는 그림의 셀만해도 서버를 18번 호출하는 것으로 보여서 망설여집니다.

이러한 복잡한 테이블을 표현할때 Mongodb의 좋은 스키마를 짜는 방법이 있는지 궁금합니다.

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

답변 1

0

김시훈 (도도소프트)

김현종님 안녕하세요 :)

일단 스키마 설계는 상황에 따라 달라지는데요.

A,B,C 각각 하나의 문서로 저장하면 어떨까 싶어요. 

각 문서는 다음과 같이 짤 수 있을거 같아요.

const ScoreSchema = new mongoose.Schema({
  studentId: { type: mongoose.Types.ObjectId, required: true, ref: 'student'},
  midterm:{
    Korean: String,
    English: String,
    Math: String
  },
  final:{
    Korean: String,
    English: String,
    Math: String
  }
})

그리고 ScoreSchema를 "수업" schema 혹은 "학생" schema에 복제해서 내장을 할 수도 있고요. 만약 지금 populate까지만 수업을 들으셨다면 조금 더 들어보시길 권장합니다. 내장 & 복제를 활용한 몽고디비스러운 스키마 설계를 자세하게 다룹니다 :)

option usecreateindex is not supported 오류 나면은

0

160

1

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

0

257

1

user 내장 시 ref 필드 필요성

0

255

1

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

0

306

2

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

0

320

1

$elemMatch 질문이 있습니다.

0

251

1

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

2

776

2

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

0

243

1

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

0

363

1

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

2

312

2

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

0

185

1

unique validation 처리

0

302

1

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

1

402

1

find() 가 리턴하는 instance member

1

437

3

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

0

609

1

인덱스 생성시점

0

720

1

$pull 문법에 대한 질문

0

366

1

comment의 id가 생성되는 시점

1

310

1

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

1

320

1

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

0

295

1

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

-1

413

1

faker 패키지 취약성 이슈

1

494

1

라우터 리팩토링

0

348

1

섹션4 진행중, mongoose 질문

0

316

1