zoukankan      html  css  js  c++  java
  • 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" ]
    }

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

  • 相关阅读:
    eclipse maven Errors while generating javadoc on java8
    log4j升级到logback
    httpclient新旧版本分割点4.3
    javadoc中{@link}与@see的简单使用以及区别
    maven-shade-plugin插件
    jar中META-INF
    dubbo环境搭建与tomcat集成、DEMO示例、常见问题(最完整版本、带管理控制台、监控中心、zookeeper)
    叶亚明:合格CTO的六要素(转)
    rocketmq安装与基本操作
    当我们在谈论技术时,技术的本质和价值究竟是什么?
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/14872590.html
Copyright © 2011-2022 走看看