Я пытаюсь найти и удалить вложенный документ с помощью _id
, но он всегда возвращает ноль.
Это моя User
схема:
// Create sub-document schema for items
var itemSchema = new mongoose.Schema ({
type: String,
colour: String,
material: String,
brand: String,
_id: String,
})
// Main user schema (incl. wardrobe)
const userSchema = new mongoose.Schema({
email: { type: String, unique: true },
password: String,
passwordResetToken: String,
passwordResetExpires: Date,
facebook: String,
twitter: String,
google: String,
github: String,
instagram: String,
linkedin: String,
steam: String,
tokens: Array,
profile: {
name: String,
gender: String,
location: String,
website: String,
picture: String
},
wardrobe: {
items: [[itemSchema]]
}
}, { timestamps: true });
Этопример объекта:
{
"_id": {
"$oid": "5c16d181c15a68c14fe2f2d3"
},
"wardrobe": {
"items": [
[
{
"type": "T-shirt",
"colour": "Black",
"material": "Wool",
"brand": "Adidas",
"_id": "5c1827dcc13025f86gfdf053"
}
],
[
{
"type": "T-shirt",
"colour": "Black",
"material": "Cotton",
"brand": "Puma",
"_id": "5c1827dfc13025f86dfaf075"
}
]
]
},
"tokens": [],
"email": "test@test.com",
"password": "$2a$10$tyCl4frHgAA1m8p6Y6kAkeAbjdYK1SJ5ghnlvWCF/MAb9.hMfR2/a",
"createdAt": {
"$date": "2018-12-16T22:28:17.777Z"
},
"updatedAt": {
"$date": "2018-12-17T23:10:02.301Z"
},
"__v": 16,
"profile": {
"gender": "",
"location": "",
"name": "Test",
"website": ""
}
}
и вот как я использую findOne
:
exports.deleteItem = (req, res, next) => {
User.findOne({"wardrobe.items._id": "5c1827dfc13025f86dfaf075"}, (err, item) => {
console.log(item);
if (err) {
return console.log("error: " + err);
}
res.redirect('/wardrobe');
});
};
console.log(item)
всегда возвращает ноль, даже если поле id является существующим документом.Есть идеи?