Как удалить объект внутри объекта с помощью MongoDB (не внутри массива)
Допустим, у меня есть эта структура:
{
"_id" : ObjectId("52af7c1497bcaf410e000002"),
"created_at" : ISODate("2013-12-16T22:17:56.219Z"),
"name" : "Hot",
"subcategories" : {
"Loco" : {
"subcategory" : "Loco",
"id" : "522423de-fffe-44be-ed3b-93fdd50fdb4f",
"products" : [ ]
},
"Loco2" : {
"subcategory" : "Loco2",
"id" : "522423de-fffe-44be-ed3b-93fdd50fd55",
"products" : [ ]
},
}
}
Как я могу удалить Loco2 из подкатегорий, оставив все остальное нетронутым?
Обратите внимание, что мой селектор объекта должен быть ObjectId, так как будут другие документы, имеющие структуру, возможно, с тем же именем подкатегории, что и другим документам. Например, у меня мог бы быть другой объект как это:
{
"_id" : ObjectId("52af7c1497bcaf410e000003"),
"created_at" : ISODate("2013-12-16T22:17:56.219Z"),
"name" : "Medium",
"subcategories" : {
"Loco" : {
"subcategory" : "Loco",
"id" : "522423de-fffe-44be-ed3b-93fdd50332b4f",
"products" : [ ]
},
"Loco2" : {
"subcategory" : "Loco2",
"id" : "522423de-fffe-44be-ed3b-93fdd522d55",
"products" : [ ]
},
}
}
Так что мой запрос должен быть таким: db.categories.update({"_id": "ObjectId("52af7c1497bcaf410e000003")"}, {don't know this part yet})
РЕДАКТИРОВАТЬ: Ответ работал на оболочку, когда я знаю название подкатегории, которую я хочу удалить, однако я не мог заставить его работать в моем приложении Node:
Categories.prototype.delSubcategory = function(categoryId, subcategory, callback) {
this.getCollection(function(error, category_collection) {
if(error) callback(error);
else {
category_collection.update(
{_id: category_collection.db.bson_deserializer.ObjectID.createFromHexString(categoryId)},
{ $unset : { "subcategories.Loco2: "" } },
function(error, subcategory) {
if(error) callback(error);
else callback(null, subcategory)
}
)
}
});
};
1 ответ
Решение
Вы можете использовать оператор $unset для удаления полей из документа или его подобъектов.
db.collection_name.update(
{"_id": ObjectId("52af7c1497bcaf410e000003")},
{ $unset : { "subcategories.Loco2" : "" } }
);