mongodb修改器(转)
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 |
db.blog.update( |
$sort 对数组中的所有对象进行排序
1 |
db.blog.update( |
$slice, $sort 必须配合 $each 与 $push使用
$addToSet
保证数组中的元素不重复
1 |
db.user.update({},{"$addToSet":{"name":"mike"}})
|
与$each组合添加多个元素
1 |
db.user.update({},{"$addToSet":{"name":{"$each":["mike", "wang"]}}})
|
$pop
从数组中删除元素,此时数组相当于队列或栈,只能从一端删除
1 |
// 从头部删除 |
$pull
删除所有匹配的文档
1 |
db.user.update({},{"pull":{"name": "mike"}})
|
数组操作符必须作用于包含数组值的键
基于位置的数组修改器
数组下标(从0开始)
1 |
db.blog.update({}, {"set":{"comments.0.name": "mike"})
|
## 定位操作符 $
1 |
db.blog.update( |
定位操作符只更新第一个匹配的元素
upsert
如果没有找到匹配的文档,那么以查询条件和更新文档为基础创建新的文档;找到则正常更新update的第三个参数表示这是个upsert
1 |
db.user.update( |
setOnInsert
在创建文档时创建字段并赋值, 在更新的时候不做任何改变
1 |
db.user.update( |
更新多个文档, 指定update的第四个参数为 true
findAndModify 返回被更新的文档
1 |
db.user.findAndModify({
|
update 和 remove 有且只有一个, 能与findAndModify 一起使用的字段有:
- query
查询文档的条件 - sort
排序的条件 - update
文档更新 - remove
删除文档,布尔类型 - new
表示返回更新前还是更新后的文档,布尔类型,默认false, 更新前的文档 - fields
文档中需要返回的字段 - upsert
true为upsert, 默认false
转自http://wangming1993.github.io/2015/12/15/mongo-modifier/
mongodb修改器(转)的更多相关文章
- mongodb修改器
mongodb修改器 转载自:http://blog.csdn.net/mcpang/article/details/7752736 mongodb修改器(\(inc/\)set/\(unset/\) ...
- 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 ...
- MongoDB修改器的使用1
为什么要使用修改器? 通常我们只会修改文档的一部分,这时候更新整个文档就显得很麻烦,通常是通过原子性的更新修改器来完成. 1."$set"修改器 "$set ...
- MongoDB修改器总结
1"$set":用来制定一个字段值,若不存在,则创建: 一般用于点加一个字段 db.users.update({name:"joe"},{" ...
- mongoDB 修改器()
-----------------------------------2016-5-26 15:56:57-- source:[1],MongoDB更新操作符
- MongoDB修改器的使用2
1."$inc"的使用 主要用来增加数值,比如网站的访问量,点击量,流量等 db.games.insert({game:"pinball",user:" ...
- mongodb的修改器
在mongodb中通常文档只会有一部分要更新,利用原子的更新修改器,可以做到只更新文档的一部分键值,而且更新极为高效,更新修改器是种特殊的键,用来指定复杂的更新操作,比如调整.增加.或者删除键,还可以 ...
- [转载]MongoDB的$inc修改器
MongoDB的$inc修改器相当于编程语言中的 “+=”“$inc”只能用于操作数值类型的数据,包括整数.长整数和双精度浮点数,用于其他类型的数据会导致操作失败. >db.users.find ...
- MongoDB之修改器
MongoDB之修改器 $set 简单粗暴 {name: valuel} 直接将key对应的值赋值给value. db.xxoo.insert({}, {set: {key: value}}) / ...
随机推荐
- 存储 磁盘大于2TB 大数据存储一个盘 解决方法
1.vmware虚拟机环境下可以做裸映射 但是一个存储 只能对应一个虚拟主机裸映射 我已经在一个10TB的存储上做好多个主机,就不适用了 2.在虚拟机上添加5个2TB磁盘,磁盘管理中新建 带区卷 可以 ...
- ES6 学习体会
第一部分: 1.初始化项目 npm init -y 2.安装ES6 环境 .babelrc 文件 babel-cli -g babel-ecmascript2015 babel-cli --save- ...
- 29个android开发常用的类、方法及接口
在安卓开发中,我们常常都需要借助各种各样的方法.类和接口来实现相关功能.提升开发效率,但对于初学者而言,什么时候该用什么类.方法和接口呢?下面小编整理了29个,日常开发中比较常用的类.方法.接口及其应 ...
- [UOJ#348][WC2018]州区划分
[UOJ#348][WC2018]州区划分 试题描述 小 \(S\) 现在拥有 \(n\) 座城市,第ii座城市的人口为 \(w_i\),城市与城市之间可能有双向道路相连. 现在小 \(S\) 要将这 ...
- [SDOI2017][bzoj4817] 树点涂色 [LCT+线段树]
题面 传送门 思路 $LCT$ 我们发现,这个1操作,好像非常像$LCT$里面的$Access$啊~ 那么我们尝试把$Access$操作魔改成本题中的涂色 我们令$LCT$中的每一个$splay$链代 ...
- 堆栈(Stacks)
堆栈(Stacks) 准备工作 安装Docker 1.13及以上版本 安装Docker Compose正如第三部分的准备工作. 安装Docker Machine正如第四部分的准备工作. 阅读第一部分的 ...
- Educational Codeforces Round 42 (Rated for Div. 2) A
A. Equator time limit per test 2 seconds memory limit per test 256 megabytes input standard input ou ...
- College student reflects on getting started in open source(一)
I just completed the first semester of my second year in college, and I'm reflecting on what I learn ...
- 创建型设计模式之工厂模式(Abstract Factory)
结构 意图 提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类. 适用性 一个系统要独立于它的产品的创建.组合和表示时. 一个系统要由多个 ...
- [LeetCode] Evaluate Reverse Polish Notation stack 栈
Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid operators are +, -, ...