ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2021-06-10 20:01:46  阅读:188  来源: 互联网

标签:tags MongoDB addToSet 修饰符 字段 数组 each id


一、定义$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" ]
}

————————————————
版权声明:本文为CSDN博主「艾米莉Emily」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yaomingyang/article/details/78697113

标签:tags,MongoDB,addToSet,修饰符,字段,数组,each,id
来源: https://www.cnblogs.com/cangqinglang/p/14872590.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有