Node.js 드라이버 형식에서 Mongoose 형식으로 MongoDB 쿼리를 조정하는 방법
Mongoose를 사용하는 쿼리 구문에 대한 도움을 주시면 감사하겠습니다.
중첩 된 개체 ID 배열에서 ObjectId를 제거하기 위해 MongoDB Node.js 드라이버를 사용하여 잘 실행되는이 쿼리가 있습니다.
let filter = { _id : new ObjectId('5f30b40839aab119f4b3e21d'), 'groups._id': new ObjectId('5f3a23ec3680923d04ff970c') };
let update = { $pull: { "groups.$.students": new ObjectId('5f1a57a9d433f86ec0750c2c') }};
client.db('database').collection('collection').findOneAndUpdate(filter, update, function(err, res) {
if (err) console.log(err);
console.log(JSON.stringify(res, null, 2));
client.close();
});
Mongoose Schema를 사용하여 쿼리를 실행하려고하면 쿼리가 배열에서 ObjectId를 제거하지 않지만 오류가 발생하지 않습니다.
let groupFilter = { _id: existingClassroom._id, 'groups._id': groupId };
let groupUpdate = { $pull: { "groups.$.students": existingUser._id } };
await Classroom.findOneAndUpdate(groupFilter, groupUpdate, {new: true}, async (err, doc) => {
if(err){
console.log(err);
}
});
Mongoose 스키마에는 다음과 같이 정의 된 이러한 필드에 대한 스키마가 있습니다.
groups:[
{
students:[
mongoose.Schema.Types.ObjectId
],
dateCreated: {
type: Date,
default: Date.now
}
}
]
답변
1 turivishal
을 사용하여 문자열 ID를 객체 ID로 변환 할 수 있습니다 mongoose.Types.ObjectId
.
let groupFilter = {
_id: mongoose.Types.ObjectId(existingClassroom._id),
'groups._id': mongoose.Types.ObjectId(groupId)
};
let groupUpdate = {
$pull: { "groups.$.students": mongoose.Types.ObjectId(existingUser._id)
}
};
await Classroom.findOneAndUpdate(groupFilter, groupUpdate, { new: true },
async (err, doc) => { if (err) { console.log(err); } }
);