MongoDB数组更新操作$addToSet和$each修饰符

一、定义$addToSet

$addToSet添加值到一个数组中去,如果数组中已经存在该值那么将不会有任何的操作。

$addToSet的操作格式如下:

{ $addToSet: { <field1>: <value1>, ... } }

二、考虑一个集合文档test,包含一个数组字段letters

{ _id: 1, letters: ["a", "b"] }

如下操作添加数组["c", "d"]到字段letters

db.test.update(
   { _id: 1 },
   { $addToSet: {letters: [ "c", "d" ] } }
)

现在letters字段包含数组["c","d"]作为一个字段

{ _id: 1, letters: [ "a", "b", [ "c", "d" ] ] }

如果想将数组中的每个元素分开添加到letters字段中,可以使用$each修饰符。


二、考虑文档集合inventory包含如下文档

{ _id: 1, item: "polarizing_filter", tags: [ "electronics", "camera" ] }

如下操作添加元素 accessories到文档集合的tags数组字段中,由于 accessories不是存在于数组中

db.inventory.update(
   { _id: 1 },
   { $addToSet: { tags: "accessories" } }
)

如下的操作 $addToSet不会对已经存在的 "camera"元素产生任何影响在tags数组中

db.inventory.update(
   { _id: 1 },
   { $addToSet: { tags: "camera"  } }
)

三、$each修饰符

你可以使用$addToSet操作符和$each修饰符配合使用,$each修饰符允许$addToSet操作符添加多个元素到数组字段中。

集合inventory有如下文档:

{ _id: 2, item: "cable", tags: [ "electronics", "supplies" ] }

如下的操作使用$addToSet操作符和$each修饰符添加多个元素到tags数组字段中:

db.inventory.update(
   { _id: 2 },
   { $addToSet: { tags: { $each: [ "camera", "electronics", "accessories" ] } } }
 )

上面的操作只会将 "camera"和"accessories"元素添加到tags数组字段中,由于"electronics"元素已经存在于数组中了。

{
  _id: 2,
  item: "cable",
  tags: [ "electronics", "supplies", "camera", "accessories" ]
}


  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值