[英]Delete Array item from mongoDB collection
我正在嘗試進行以下操作,如果有人可以提供幫助,那將是非常有幫助的
我想從 items 數組中刪除一個項目
{
"_id" : ObjectId("56e8c56a71cfa3fbe528c91b"),
"shipping" : 6.7800000000000002,
"subTotal" : 201,
"totalCost" : 207.7800000000000011,
"order_status" : "queued",
"ordered_by" : "John Sims",
"ordered_by_id" : "56e8c50a71cfa3fbe5288a48",
"created_at" : ISODate("2016-03-16T02:31:06.723Z"),
"items" : [
{
"created_at" : "2008-12-17T11:01:23.460Z",
"quantity" : 1,
"country" : "Australia",
"state" : "NSW",
"suburb" : "Sydney",
"location" : "Sydney,NSW,Australia",
"longitude" : "151.1228434",
"latitude" : "-33.7904955",
"genre" : "Rock",
"cost" : "67",
"product_status" : "pending",
"product_by" : "Paul Dirac",
"item" : "CD",
"cart_id" : "56e8c56271cfa3fbe528c918"
},
{
"created_at" : "2008-12-17T11:01:23.460Z",
"quantity" : 1,
"country" : "Australia",
"state" : "QLD",
"suburb" : "Brisbane",
"location" : "Brisbane,NSW,Australia",
"longitude" : "151.1228434",
"latitude" : "-33.7904955",
"genre" : "",
"cost" : "67",
"product_status" : "pending",
"product_by" : "Paul Dirac",
"item" : "DVD",
"cart_id" : "56e8c56571cfa3fbe528c919"
}
]
}
基於如下條件
// Updates an existing order in the DB.
exports.updateArray = function(req, res) {
Order.findById(req.params.id, function (err, order) {
if (err) { return handleError(res, err); }
if(!order) { return res.send(404); }
order.update(
// query
{
},
// update
{
$pull:{
items:{
"item" : "CD"
}
}
}
);
order.save(function (err) {
if (err) { return handleError(res, err); }
return res.json(200, order);
});
});
};
現在更新代碼運行並從項目中刪除項目時從 shell 執行以下代碼
db.getCollection('orders').update(
// query
{
},
// update
{$pull:{
items:{
item:'CD'
}
}
},
// options
{
"multi" : false, // update only one document
"upsert" : false // insert a new document, if no existing document match the query
}
);
但是當遇到 put 或 delete 請求時,這不會從特定文檔的 items 數組中刪除該項目。 如果有人能幫我弄清楚需要更改代碼以使其通過 HTTP 請求發生,那就太好了。
謝謝
db.collection.findOneAndUpdate({_id:'56e8c56a71cfa3fbe528c91b'}, {$pull:{"items.item":"cd"}},{new:true},function(err,object{ });
你可以使用 $拉入 mongodb 查詢。我在 ndoe js 中的 mongoose 中使用了這個查詢,它可能對我有用..
工作解決方案現在是這樣
exports.updateArray = function(req, res) {
Order.update(
// query
{
_id:req.params.id
},
// update
{
$pull:{
items:{
item:itemdata
}
}
},function(err){
return res.send(204);
}
);
};
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.