왜 몽구스는 스키마와 모델을 모두 가지고 있을까요?
두 가지 유형의 물체는 서로 너무 가까워서 둘 다 중복된 것처럼 느껴집니다.스키마와 모델을 모두 갖추는 것이 무슨 의미가 있습니까?
편집: 이것은 많은 사람들에게 유용했지만, 코멘트에서도 언급되었듯이, 그 이유는 아닌 "어떻게"에 대한 답변입니다.고맙게도, 질문의 이유는 다른 곳에서도 답변이 되었고, 이 답변은 또 다른 질문에 대한 답변입니다.이것은 한동안 댓글에 링크되어 있었지만 나는 많은 사람들이 읽을 때 그렇게 멀리 가지 않을 수도 있다는 것을 깨달았다.
이런 종류의 질문에 대답하는 가장 쉬운 방법은 예를 들어 답하는 것입니다.이 경우, 누군가가 이미 해 주었습니다. :)
여기를 봐주세요.
http://rawberg.com/blog/nodejs/mongoose-orm-nested-models/
편집: 원래의 투고(댓글에 기재되어 있는 대로)가 없어져 버려서, 이하에 재현합니다.만약 다시 돌아오거나 방금 움직이면 알려주세요.
mongoose의 모델 내에서 스키마를 사용하는 방법과 원하는 이유를 적절하게 설명하고 스키마가 구조 등에 관한 모든 것을 다루고 있는 동안 모델을 통해 태스크를 푸시하는 방법도 보여줍니다.
원본 투고:
모델 내에 스키마를 삽입하는 간단한 예부터 살펴보겠습니다.
var TaskSchema = new Schema({
name: String,
priority: Number
});
TaskSchema.virtual('nameandpriority')
.get( function () {
return this.name + '(' + this.priority + ')';
});
TaskSchema.method('isHighPriority', function() {
if(this.priority === 1) {
return true;
} else {
return false;
}
});
var ListSchema = new Schema({
name: String,
tasks: [TaskSchema]
});
mongoose.model('List', ListSchema);
var List = mongoose.model('List');
var sampleList = new List({name:'Sample List'});
는 새로운 i i i i i i i i i i i 。TaskSchema
작업의 기본 정보가 포함된 개체입니다.Mongoose 가상 속성은 태스크의 이름과 우선순위를 편리하게 결합하도록 설정됩니다.여기서 getter만 지정했는데 가상 세터도 지원됩니다.
인 '직접 하다'도 했습니다.isHighPriority
이 셋업에서 메서드가 어떻게 동작하는지를 나타냅니다.
서서 ListSchema
하면 알 수 tasks
는, 「키」의 유지하도록 되어 있습니다.TaskSchema
★★★★★★★★★★★★★★★★★.task
키는 삽입 Mongo 문서를 처리하는 특별한 방법을 제공하는 인스턴스가 됩니다.
지금으로서는 합격만 했어요.ListSchema
를 제기하다mongoose.model
그 자리를 .TaskSchema
엄밀히 따지자면 이 모든 걸 바꿀 필요는 없어TaskSchema
을 사용하다 왜냐하면 우리는 그것을 자체 컬렉션에 저장하지 않을 것이기 때문입니다.나중에 여러 파일에 걸쳐 모든 모델을 동일한 방식으로 구성할 수 있는 방법에 대해 설명하겠습니다.
★List
모델 셋업에 몇 가지 작업을 추가하여 Mongo에 저장합니다.
var List = mongoose.model('List');
var sampleList = new List({name:'Sample List'});
sampleList.tasks.push(
{name:'task one', priority:1},
{name:'task two', priority:5}
);
sampleList.save(function(err) {
if (err) {
console.log('error adding new list');
console.log(err);
} else {
console.log('new list successfully saved');
}
});
의 List
모델명)sampleList
하며 푸시를 하여 새로운 할 수 는 일반 JavaScript 배열과 동일하게 동작하며 push를 사용하여 새로운 작업을 추가할 수 있습니다.할 점은 '아까운 것'tasks
JavaScript를 사용합니다.바로 직감할 수 없는 미묘한 차이입니다.
Mongo 쉘에서 새 목록과 작업이 Mongo에 저장되었는지 확인할 수 있습니다.
db.lists.find()
{ "tasks" : [
{
"_id" : ObjectId("4dd1cbeed77909f507000002"),
"priority" : 1,
"name" : "task one"
},
{
"_id" : ObjectId("4dd1cbeed77909f507000003"),
"priority" : 5,
"name" : "task two"
}
], "_id" : ObjectId("4dd1cbeed77909f507000001"), "name" : "Sample List" }
, 그럼 에는 '어울리지 않다'를.ObjectId
Sample List
작업을 반복할 수 있습니다.
List.findById('4dd1cbeed77909f507000001', function(err, list) {
console.log(list.name + ' retrieved');
list.tasks.forEach(function(task, index, array) {
console.log(task.name);
console.log(task.nameandpriority);
console.log(task.isHighPriority());
});
});
isHighPriority
현재 버전의 Mongoose에서는 내장된 스키마의 메서드에 직접 액세스할 수 없습니다.이 문제를 해결할 수 있는 오픈 티켓이 있으며, Mongoose Google Group에 문제를 제기한 후 manimal45는 현재 유용한 해결 방법을 게시했습니다.
List.findById('4dd1cbeed77909f507000001', function(err, list) {
console.log(list.name + ' retrieved');
list.tasks.forEach(function(task, index, array) {
console.log(task.name);
console.log(task.nameandpriority);
console.log(task._schema.methods.isHighPriority.apply(task));
});
});
이 코드를 실행하면 명령줄에 다음 출력이 표시됩니다.
Sample List retrieved
task one
task one (1)
true
task two
task two (5)
false
이 에 두고 이번에는 이 문제를 하겠습니다.TaskSchema
몽구스 모델로 만들었죠
mongoose.model('Task', TaskSchema);
var Task = mongoose.model('Task');
var ListSchema = new Schema({
name: String,
tasks: [Task.schema]
});
mongoose.model('List', ListSchema);
var List = mongoose.model('List');
TaskSchema
츠키노모델이 된 후에도 도트 표기법을 사용하여 기본 스키마 개체에 액세스할 수 있습니다.
새 목록을 만들고 그 안에 두 개의 작업 모델 인스턴스를 포함하도록 하겠습니다.
var demoList = new List({name:'Demo List'});
var taskThree = new Task({name:'task three', priority:10});
var taskFour = new Task({name:'task four', priority:11});
demoList.tasks.push(taskThree.toObject(), taskFour.toObject());
demoList.save(function(err) {
if (err) {
console.log('error adding new list');
console.log(err);
} else {
console.log('new list successfully saved');
}
});
때, 「」를 호출하고 있습니다.toObject
를 JavaScript에서 개체로 합니다.List.tasks
DocumentArray
기다리고 있습니다.으로 모델 를 저장하면 에는 델델인 will will will will will will음음음음음음음음음 will will will will will will will will will will will will will will will가 포함됩니다.ObjectIds
.
완전한 코드 예는 요지로 사용할 수 있습니다.바라건대 이러한 회피책이 Mongoose가 계속 발전함에 따라 상황을 원만하게 해결하는데 도움이 되기를 바란다.저는 아직 Mongoose와 MongoDB에 익숙하지 않기 때문에 더 좋은 해결책과 팁을 자유롭게 댓글로 공유해 주세요.행복한 데이터 모델링!
스키마는 MongoDB 컬렉션에 저장될 문서의 구조를 정의하는 개체로, 모든 데이터 항목에 대한 유형과 검증자를 정의할 수 있습니다.
모델은 명명된 컬렉션에 쉽게 액세스할 수 있는 개체로, 컬렉션을 쿼리하고 스키마를 사용하여 해당 컬렉션에 저장한 문서의 유효성을 확인할 수 있습니다.스키마, 연결 및 컬렉션 이름을 결합하여 생성됩니다.
원문: Valeri Karpov, MongoDB 블로그
나는 받아들여진 답변이 실제로 제기된 질문에 대답한다고 생각하지 않는다.Mongoose가 개발자에게 Schema 변수와 Model 변수를 모두 제공하도록 결정한 이유는 설명되지 않습니다.개발자가 데이터 스키마를 정의할 필요가 없어진 프레임워크의 예로는 django가 있습니다.개발자는 모델을 models.py 파일에 기록하고 스키마를 관리하기 위해 프레임워크에 맡깁니다.왜 이렇게 하는지 가장 먼저 떠오르는 이유는 장고를 사용해 본 경험으로 미루어 볼 수 있듯이 사용하기 쉽기 때문입니다.더 중요한 것은 모델을 변경할 때 스키마를 갱신할 필요가 없다는 DRY(반복하지 말 것) 원칙입니다.django가 대신합니다.또한 개발자는 스키마를 직접 편집하지 않고 스키마를 조작하는 마이그레이션을 정의하여 변경함으로써 데이터 스키마를 대신 관리할 수 있습니다.
Mongoose가 스키마와 모델을 분리하는 것은 두 개의 스키마에서 모델을 구축하려는 경우라고 이해할 수 있습니다.이러한 시나리오로 인해 관리 가치가 있는 것보다 더 복잡해질 수 있습니다. 한 모델에서 관리하는 스키마가 두 개인 경우, 두 스키마가 하나의 스키마가 아닌 이유는 무엇입니까?
아마도 원래의 질문은 전통적인 관계형 데이터베이스 시스템의 유물일 것이다.NoSQL/Mongo 세계에서는 스키마가 MySQL/Postgre보다 조금 더 유연합니다.SQL, 따라서 스키마를 변경하는 것이 더 일반적인 방법입니다.
왜 그런지 이해하려면 몽구스가 실제로 무엇인지 이해해야 해?
음, mongoose는 MongoDB와 노드 JS를 위한 객체 데이터 모델링 라이브러리이며, 더 높은 수준의 추상화를 제공합니다.Express와 Node의 관계와 비슷하기 때문에 Express는 일반 노드 상의 추상화 레이어이며 Mongoose는 일반 MongoDB 드라이버 상의 추상화 레이어입니다.
오브젝트 데이터 모델링 라이브러리는 데이터베이스와 상호작용하는 Javascript 코드를 작성하는 방법일 뿐입니다.일반 MongoDB 드라이버를 사용하여 데이터베이스에 액세스하면 문제없이 작동합니다.
대신 Mongoose를 사용하는 이유는 바로 사용할 수 있는 기능이 훨씬 많기 때문입니다.이 기능을 사용하면 애플리케이션을 보다 빠르고 쉽게 개발할 수 있기 때문입니다.
그래서 Mongoose는 데이터와 관계를 모델링하기 위한 스키마, 간단한 데이터 검증, 단순한 쿼리 API, 미들웨어 등을 제공합니다.
Mongoose에서는 스키마를 사용하여 데이터를 모델링하고 데이터 구조, 기본값 및 검증을 기술한 후 스키마를 사용하여 모델을 만듭니다.모델은 기본적으로 스키마 주위에 랩퍼로 되어 있습니다.데이터베이스와인터페이스하여문서를작성,삭제,갱신,읽기를실수있습니다.
스키마에서 모델을 만듭니다.
const tourSchema = new mongoose.Schema({
name: {
type: String,
required: [true, 'A tour must have a name'],
unique: true,
},
rating: {
type: Number,
default: 4.5,
},
price: {
type: Number,
required: [true, 'A tour must have a price'],
},
});
//tour model
const Tour = mongoose.model('Tour', tourSchema);
대류에 따라 모델 이름의 첫 글자는 대문자로 표시되어야 합니다.
mongoose와 schema를 사용하여 만든 모델의 인스턴스를 만듭니다.데이터베이스와 대화할 수도 있습니다.
const testTour = new Tour({ // instance of our model
name: 'The Forest Hiker',
rating: 4.7,
price: 497,
});
// saving testTour document into database
testTour
.save()
.then((doc) => {
console.log(doc);
})
.catch((err) => {
console.log(err);
});
그래서 샤마와 모들 몽구스가 둘 다 있으면 우리의 삶이 더 편해진다.
모델을 스키마에 대한 래퍼라고 생각하십시오.스키마는 문서의 구조, 예상되는 속성 및 데이터 유형(String, Number 등)을 정의합니다.모델은 스키마에서 CRUD를 수행하기 위한 일종의 인터페이스를 제공합니다.FCC의 이 투고를 참조해 주세요.
스키마는 기본적으로 데이터를 모델링하고(필드에 데이터 유형을 제공) 데이터에 대해 몇 가지 검증을 수행할 수 있습니다.주로 컬렉션의 구조를 다루고 있습니다.
반면 모델은 스키마를 감싸는 래퍼로 컬렉션에 대한 CRUD 메서드를 제공합니다.주로 데이터베이스 추가/쿼리를 다룹니다.
Django(모델만 제공)나 SQL(Schema만 만들고 SQL 쿼리만 작성하며 모델 개념은 없음)과 같은 다른 프레임워크와 비교하면 스키마와 모델이 모두 있는 것처럼 보일 수 있습니다.하지만, 이것은 몽구스가 그것을 구현하는 방식일 뿐이다.
언급URL : https://stackoverflow.com/questions/9127174/why-does-mongoose-have-both-schemas-and-models
'programing' 카테고리의 다른 글
React가 있는 Wordpress 플러그인의 쇼트 코드 특성 (0) | 2023.03.06 |
---|---|
리액트 및 웹팩을 사용하여 Babel 6 Stage 0을 설정하는 방법 (0) | 2023.03.06 |
'Element' 형식의 인수는 'ReactElement' 형식의 매개 변수에 할당할 수 없습니다. (0) | 2023.03.06 |
Autoahead.js 0.10 단계별 / remote / prefetch / local 사용방법 (0) | 2023.03.06 |
경로 변수를 사용하여 th:href에 대한 타임 리프 (0) | 2023.03.06 |