zoukankan      html  css  js  c++  java
  • 10.mongoDB给所有文档添加字段

    与更新现有集合字段相同,$set如果指定的字段不存在,将添加新的字段。

    看看这个例子:

    > db.foo.find()
    
    > db.foo.insert({"test":"a"})
    
    > db.foo.find()
    
    { "_id" : ObjectId("4e93037bbf6f1dd3a0a9541a"), "test" : "a" }
    
    > item = db.foo.findOne()
    
    { "_id" : ObjectId("4e93037bbf6f1dd3a0a9541a"), "test" : "a" }
    
    > db.foo.update({"_id" :ObjectId("4e93037bbf6f1dd3a0a9541a") },{$set : {"new_field":1}})
    
    > db.foo.find()
    
    { "_id" : ObjectId("4e93037bbf6f1dd3a0a9541a"), "new_field" : 1, "test" : "a" }

    编辑:

    如果要向所有集合中添加new_field,则必须使用空选择器,并将multi标志设置为true(最后一个参数)以更新所有文档

    db.your_collection.update(
      {},
      { $set: {"new_field": 1} },
      false,
      true
    )

    编辑:

    在上面的示例中,最后2个字段false, true指定upsert和multi标志。

    Upsert: 如果设置为true,则在没有文档符合查询条件时创建一个新文档。

    多个: 如果设置为true,则更新满足查询条件的多个文档。如果设置为false,则更新一个文档。

    这是Mongo versions之前的2.2。对于最新版本,查询有所更改

    db.your_collection.update({},
    
                              {$set : {"new_field":1}},
    
                              {upsert:false,
    
                              multi:true})
    穷则独善其身,达则兼济天下……
  • 相关阅读:
    mybatis动态SQl中int类型字段为0 SQl语句不拼接
    Ansible学习(pyenv与virtualenv)
    word
    github学习
    OpenStack搭建遇到的问题2(组件配置错误了,别重装全部,就把模块卸载就行了)
    OpenStack搭建遇到的问题
    Ubuntu 17.04 安装
    docker学习(一)
    MySQL安装
    来自Google的响应式——Agera
  • 原文地址:https://www.cnblogs.com/hmy-666/p/14736167.html
Copyright © 2011-2022 走看看