MongoDB 修改器

对文档中的某些字段进行更新

$inc

专门用来增加(或减少)数字的,只能用于整数,长整数或双精度浮点型的值
$inc键的值必须为数字,不能使用字符串,数组或其他非数字的值
如果键不存在,则创建它

1
db.user.update({}, {"$inc":{"age":1}});

$set

用来指定一个字段的值, 字段不存在则创建.

1
db.user.update({},{"$set":{"name":"mike"}})

$set 也可以用于改变键的类型

1
db.user.update({}, {"$set":{"name":["mike","wang"]}})

unset

用于删除一个键

1
db.user.update({},{"$unset":{"age":1}})

数组修改器

$push

如果数组已存在,添加元素到数组末尾,否则创建它

1
db.blog.update({}, {"$push":{"authors":"mike"}})

使用$each 添加多个值

1
db.blog.update({},{"$push":{"authors":{"$each":["mike", "wang"]}}})

限制数组的最大长度 ‘$slice’, 只包含最后加入的限制长度的元素,必须为负整数,
$slice相对于在文档中创建了一个队列

1
2
3
4
5
6
7
8
9
db.blog.update(
{},
{"$push":{
"authors":{
"$each":["mike", "wang"],
"$slice":-5
}
}
})

$sort 对数组中的所有对象进行排序

1
2
3
4
5
6
7
8
9
10
11
db.blog.update(
{},
{"$push":{
"comments":{
"$each":[{"name": "mike", "count": 2},
{"name": "wang", "count": 3}],
"$slice":-5,
"$sort":{"count": -1}
}
}
})

$slice$sort 必须配合 $each 与 $push使用

$addToSet

保证数组中的元素不重复

1
db.user.update({},{"$addToSet":{"name":"mike"}})

$each组合添加多个元素

1
db.user.update({},{"$addToSet":{"name":{"$each":["mike", "wang"]}}})

$pop

从数组中删除元素,此时数组相当于队列或栈,只能从一端删除

1
2
3
4
// 从头部删除
db.user.update({},{"pop":{"name": -1}})
// 从数组末尾删除
db.user.update({},{"pop":{"name": -1}})

$pull

删除所有匹配的文档

1
db.user.update({},{"pull":{"name": "mike"}})

数组操作符必须作用于包含数组值的键

基于位置的数组修改器

数组下标(从0开始)

1
db.blog.update({}, {"set":{"comments.0.name": "mike"})

## 定位操作符 $

1
2
3
4
db.blog.update(
{"comments.name": "mike"},
{"$set": {"comments.$.name": "wang"}
);

定位操作符只更新第一个匹配的元素

upsert

如果没有找到匹配的文档,那么以查询条件和更新文档为基础创建新的文档;找到则正常更新
update的第三个参数表示这是个upsert

1
2
3
4
5
db.user.update(
{"age": 23},
{"$set": {"age": 24}},
true
)

setOnInsert

在创建文档时创建字段并赋值, 在更新的时候不做任何改变

1
2
3
4
5
db.user.update(
{"age": 23},
{"$setOnInsert": {"name": "mike"}},
true
)

更新多个文档, 指定update的第四个参数为 true

findAndModify 返回被更新的文档

1
2
3
4
5
db.user.findAndModify({
"query":{"name":"mikewang"},
"update":{"$set":{"name":"mike"}},
"new":1
})

update 和 remove 有且只有一个, 能与findAndModify 一起使用的字段有:

    • query
      查询文档的条件
    • sort
      排序的条件
    • update
      文档更新
    • remove
      删除文档,布尔类型
    • new
      表示返回更新前还是更新后的文档,布尔类型,默认false, 更新前的文档 
    • fields
      文档中需要返回的字段
    • upsert
      true为upsert, 默认false

转自http://wangming1993.github.io/2015/12/15/mongo-modifier/

mongodb修改器(转)的更多相关文章

  1. mongodb修改器

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

  2. 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 ...

  3. MongoDB修改器的使用1

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

  4. MongoDB修改器总结

    1"$set":用来制定一个字段值,若不存在,则创建:    一般用于点加一个字段   db.users.update({name:"joe"},{" ...

  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. Dubbo基础介绍

    基础知识 Dubbo是什么:Dubbo是一个分布式的服务框架,提供高性能和透明化的RPC远程调用方案,以及SOA服务治理方案 Dubbo涉及的知识: 远程调用:RMI.hassion.webservi ...

  2. 利用反射修改final数据域

    当final修饰一个数据域时,意义是声明该数据域是最终的,不可修改的.常见的使用场景就是eclipse自动生成的serialVersionUID一般都是final的. 另外还可以构造线程安全(thre ...

  3. HDU 6034 Balala Power!(贪心+排序)

    Balala Power! Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  4. [AGC010E] Rearranging [拓扑排序+堆]

    题面 传送门 思路 首先,一个显然的结论是:Alice调整过后的序列中任意两个不互质的数的相对顺序无法改变 那么我们可以以这个性质为突破口 我们在两个不互质的权值的点之间连一条边(没错这是个图论题!! ...

  5. 2-SAT学习整理

    关于2-SAT 问题给出的证明和思路就不再赘述 核心是对于问题给出的条件建图,然后跑tarjan缩点 (在一个强联通分量里bool值是相同的) 看集合两个元素是否在一个强联通分量来判断是否合法 利用强 ...

  6. 「JOISC 2015 Day 1」卡片占卜

    题目描述 K 理事长是占卜好手,他精通各种形式的占卜.今天,他要用正面写着 I ,背面写着 O 的卡片占卜一下日本 IOI 国家队的选手选择情况. 占卜的方法如下: 首先,选取五个正整数 A,B,C, ...

  7. Build RPM package from source code

    # yum install rpm-build# wget http://rsync.samba.org/ftp/rsync/rsync-3.0.9.tar.gz# vim rsync.specNam ...

  8. urllib2.URLError: <ulropn error [Errno 10060] >

    在抓网页的时候,如果抓取频率很高,很容易出现这个错误: 意思是服务器拒绝响应.解决的方法为,隔段时间再试,不过这个方法不靠谱.靠谱的方法是增加一个延迟函数 import time time.sleep ...

  9. GHC extensions

    OverloadedStrings 这是最常见的一个扩展,很多时候都能看到   Haskell中,数字是num的多态,比如:   a :: Int a = 1   b :: Double b = 1 ...

  10. OpenGL 之 坐标变换

    http://www.cnblogs.com/irvinow/archive/2009/11/20/1606496.html 创建OpenGL模型过程: OPENGL坐标变换很有特点,为了简单描述先定 ...