MongoDB 데이터 구조에 대해 질문 있습니다.
217
작성한 질문수 5
안녕하세요. 강의를 듣고 궁금한 점이 생겨서 여쭤봅니다.
이러한 모양의 테이블이나 이보다 더 복잡한 테이블의 셀안의 값을 표현하고자 할때의 질문이 있습니다.
저러한 모양의 스키마를 짜서 내장이나 populate하는 것은 document가 길어질 수록 셀에 표현될 값을 탐색하는데 어려움이 있습니다.
그렇다고 각 셀마다 저기에 맞는 값을 호출해서 표현하기에는 그림의 셀만해도 서버를 18번 호출하는 것으로 보여서 망설여집니다.
이러한 복잡한 테이블을 표현할때 Mongodb의 좋은 스키마를 짜는 방법이 있는지 궁금합니다.
답변 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





