码迷,mamicode.com
首页 > 数据库 > 详细

mongodb中$push和$pull的使用,向内嵌的数组中删除和添加元素

时间:2020-01-18 12:30:56      阅读:404      评论:0      收藏:0      [点我收藏+]

标签:相互   model   targe   null   引用   直接   set   ODB   并且   

mongodb中$push和$pull的使用,向内嵌的数组中删除和添加元素

假设在集中在存在如下数据:

{
  "_id" : ObjectId("5cb6e53cb4276075a2262f5b"),
  "results" : [
  {
    "current" : 7.45,
    "origin" : 0,
    "target" : 100,
    "title" : "组织kr",
    "type" : 2,
    "director" : "c673e19320f1461d859f5c8703f7c47f",
    "indepartmental_needs" : "组织kr",
    "_id" : ObjectId("5cb7e9ba439a2716f888c14d"),
    "arr" : [
    {
      "_id" : 1,
      "kid" : 1,
      "parent_id" : null
    },
    {
      "_id" : 2,
      "kr_id" : 2,
      "parent_id" : 1
    },
    {
      "_id" : 3,
      "kr_id" : 3,
      "parent_id" : 1
    },
    {
      "_id" : 4,
      "kr_id" : 3,
      "parent_id" : 1
    },
    {
      "_id" : 5,
      "kr_id" : 1,
      "parent_id" : 1
    }
  ],
},

 



很明显,这个数据的结构是层层嵌套的,并且arr数组中存储了一个打平的父子相互引用的树结构,
需求1:
需要再向arr数组中添加元素:

this.model.findOneAndUpdate(
{
  results._id:mongoose.Types.ObjectId(body.ancestors)
},
{
  $push:
  {
    "results.$.arr":
  {
    parent_id : 1,
    kr_id : 1
  } 
  }
},
{
  upsert:true,
  new:true
} ,
(err,data)=>{
  //return
}
);

 

$符号是mongodb中的占位符,也就是说当我们指定一个位置或匹配到一个元素之后,这个符号会自动指向平级的元素来进行操作,

push是直接向数组中进行添加,如果不想添加重复的元素,可以选择使用push是直接向数组中进行添加,如果不想添加重复的元素,可以选择使用push是直接向数组中进行添加,如果不想添加重复的元素,可以选择使用addToSet

需求2:
删除内嵌数组中的某一元素:

this.model.findOneAndUpdate(
{
  "results._id":mongoose.Types.ObjectId(ancestors_id)
},
{
$pull:
{
  "results.$.relation_kr_draft":{
  _id: { 
    $in : arr 
  }
  }
}
}
);

 

同样的,我们在这里还是使用了$占位符,在我们匹配到元素之后,占位符也自动匹配
————————————————
版权声明:本文为CSDN博主「多比熊」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_42427109/article/details/89426172

mongodb中$push和$pull的使用,向内嵌的数组中删除和添加元素

标签:相互   model   targe   null   引用   直接   set   ODB   并且   

原文地址:https://www.cnblogs.com/Joans/p/12208607.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!