猿问

MongoDB,从数组中删除对象

MongoDB,从数组中删除对象

文档:

{
   _id: 5150a1199fac0e6910000002,
   name: 'some name,
   items: [{
      id: 23,
      name: 'item name 23'
   },{
      id: 24,
      name: 'item name 24'
   }]}

有没有办法从数组中提取特定对象?IE如何从items数组中提取id为23的整个item对象。

我试过了:

db.mycollection.update({'_id': ObjectId("5150a1199fac0e6910000002")}, {$pull: {id: 23}});

但是我很确定我没有正确使用'pull'。根据我的理解,pull将从数组中提取字段而不是对象。

任何想法如何将整个对象拉出阵列。

作为奖励,我试图在mongoose / nodejs中执行此操作,并且不确定这种类型的东西是否在mongoose API中但我找不到它。


慕斯王
浏览 565回答 3
3回答

哔哔one

尝试..db.mycollection.update(     {'_id': ObjectId("5150a1199fac0e6910000002")},      { $pull: { "items" : { id: 23 } } },false,true );

侃侃尔雅

我有一个类似的文件我必须从地址数组中删除地址在网上搜索了很多我找到了解决方案Customer.findOneAndUpdate(query, {$pull: {address: addressId}}, function(err, data){         if(err) {           return res.status(500).json({'error' : 'error in deleting address'});         }         res.json(data);       });

慕侠2389804

my database:->         {        "_id" : ObjectId("5806056dce046557874d3ab18"),        "data" : [             {                "id" : 1            },             {                "id" : 2            },             {                "id" : 3            }        ]     }MY QUERY:->db.getCollection('play_table').update({},{$pull:{"data":{"id":3}}},{multi:true}OutPut:->{   "_id" : ObjectId("5806056dce046557874d3ab18"),        "data" : [             {                "id" : 1            },             {                "id" : 2            }        ]     }
随时随地看视频慕课网APP
我要回答