1"$set":用来制定一个字段值,若不存在,则创建;

   一般用于点加一个字段

  db.users.update({name:"joe"},{"$set":{"favorite book":"War and Peace"}})

  还可以修改一个字段

  db.users.update({name:"joe"},{"$set":{"favorite book":"Your"}})

 还可以删除

  db.users.update({name:"joe"},{"$unset":{"favorite book":"Your"}})

2"$inc":增加或者减少

                用来增加已有的键的值,不存在则创建一个,比如某网站的访问量

 db.users.update({name:"joe"},{"$inc":{"score":1}})

 每次访问都会增加1

3"$push":会向已有的数组末尾添加一个元素,要是没有,创建一个新的数组。

  比如要添加一个评论:
  db.users.update({name:"joe"},{"$push":{"comments":{"name":"joe","email":"joe@yahoo.com","conment":"nice"}}})

 还想添加,继续修改即可

db.users.update({name:"joe"},{"$push":{"comments":{"name":"bob","email":"bob@yahoo.com","conment":"good"}}})

4."$each"

      "$each"与"$push"结合,可以操作复杂的数组。可以一次添加多个值

var users={"username":"joe",
          "email":[
                       "joe@example.com",
                       "joe@exam.com",
                     "joe@yahoo.com"]}
 db.users.insert(users)
 db.users.find()
 db.users.update({"username":"joe"},
                          {"$addToSet":{"email":"joe@mail.com"}})
 db.users.update({"username":"joe"},
                           {"$addToSet":{
                                     "email":{
                                     "$each":["joe@qq.com","joe@Hadoop.com","joe@python.com"]}}})

结果展示:
   

{
"_id" : ObjectId("57600ffd73b4b5108cfff9b0"),
    "username" : "joe",
   "email" : [
   "joe@example.com",
   "joe@exam.com",
   "joe@yahoo.com",
   "joe@mail.com",
   "joe@qq.com",
    "joe@Hadoop.com",
  "joe@python.com"
   ]
}

5"$pop""$pull"删除元素的方法。类似于堆栈中的出栈操作
  

db.lists.insert({"todo":["dishes","laundry","dry cleaning"]})
db.lists.find()
db.lists.update({},{"$pull":{"todo":"laundry"}})

6基于位置的修改可以使用定位操作符"$"

  如: db.blog.plogs.update({"post","post_id"},

                                             {"$inc":"comments.0.votes":1})

   实际在数据库中,数组的下标很难确定,我们采用

  db.blog.update({"comments.author":"Jim"},

                             {"$set":{"comments.$.author":"Wade"}})

MongoDB修改器总结的更多相关文章

  1. mongodb修改器

    mongodb修改器 转载自:http://blog.csdn.net/mcpang/article/details/7752736 mongodb修改器(\(inc/\)set/\(unset/\) ...

  2. mongodb修改器(转)

    MongoDB 修改器 对文档中的某些字段进行更新 $inc 专门用来增加(或减少)数字的,只能用于整数,长整数或双精度浮点型的值$inc键的值必须为数字,不能使用字符串,数组或其他非数字的值如果键不 ...

  3. Mongodb更新数组$pull修饰符 (mongodb 修改器($inc/$set/$unset/$push/$pop/upsert))

    mongodb 修改器($inc/$set/$unset/$push/$pop/upsert))   https://www.jb51.net/article/112588.htm http://bl ...

  4. MongoDB修改器的使用1

    为什么要使用修改器?     通常我们只会修改文档的一部分,这时候更新整个文档就显得很麻烦,通常是通过原子性的更新修改器来完成. 1."$set"修改器    "$set ...

  5. mongoDB 修改器()

    -----------------------------------2016-5-26 15:56:57-- source:[1],MongoDB更新操作符

  6. MongoDB修改器的使用2

    1."$inc"的使用 主要用来增加数值,比如网站的访问量,点击量,流量等 db.games.insert({game:"pinball",user:" ...

  7. mongodb的修改器

    在mongodb中通常文档只会有一部分要更新,利用原子的更新修改器,可以做到只更新文档的一部分键值,而且更新极为高效,更新修改器是种特殊的键,用来指定复杂的更新操作,比如调整.增加.或者删除键,还可以 ...

  8. [转载]MongoDB的$inc修改器

    MongoDB的$inc修改器相当于编程语言中的 “+=”“$inc”只能用于操作数值类型的数据,包括整数.长整数和双精度浮点数,用于其他类型的数据会导致操作失败. >db.users.find ...

  9. MongoDB之修改器

    MongoDB之修改器 $set  简单粗暴  {name: valuel} 直接将key对应的值赋值给value. db.xxoo.insert({}, {set: {key: value}}) / ...

随机推荐

  1. 241. Different Ways to Add Parentheses

    241. Different Ways to Add Parentheses https://leetcode.com/problems/different-ways-to-add-parenthes ...

  2. 如何删除选中的checkbox

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. Effecvive Java读书笔记(一):创建和销毁对象

    I.考虑静态工厂方法替代构造器 优势:1.有清晰的方法名称,方便调用:多参数构造器易出现调用错误 2.不必每次调用都创建新对象 3.可以返回原返回类型的任何子类型 4.创建参数化类型实例的时候,代码简 ...

  4. PhoneGap(二维码扫描 )

    关于 phoneGap 如何做 二维码扫描 1.        先配置好, 环境 http://coenraets.org/blog/cordova-phonegap-3-tutorial/http: ...

  5. Android学习地址

    Google Android官方培训课程中文版http://hukai.me/android-training-course-in-chinese/

  6. C++容器之Vector

    vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说vect ...

  7. dbca静默建库和删除库

    dbca查看帮助: [oracle@wen ~]$ dbca -help 1).运行静默建库语句 [oracle@wen ~]$ dbca -silent -cloneTemplate -gdbNam ...

  8. SQL Saturday活动再起

    SQL Saturday活动再起 时间:2015年05月09日(星期六) 地点:上海徐汇区港汇2座10楼(10.073) 我们相约港汇2座10楼(10.073),SQL PASS上海分会的SQLSat ...

  9. VS2012配置使用ICE通信接口

    1.下载安装Ice-3.5.1.msi http://www.zeroc.com/download.html 2.添加安装路径到环境变量path,D:\Program Files (x86)\Zero ...

  10. Entity FrameWork 中使用Lambda访问数据库性能优化

    在使用Entity Framework 访问数据库时,我们经常使用Lambda表达式,但是如果不小心的话,很容易就掉到坑里了.比如下面的例子:用Lambda访问MSSqlServer中的NewsInf ...