创建、更新和删除文档
1. 插入并保存:
1). 单条插入,insert : db.foo.insert({"bar":"baz"})
2). 批量插入,batchInsert : db.foo.insert([{"_id":0},{"_id":1}])
3). 要是只导入原始数据(例如:从数据feed或者mysql中导入),可以使用命令行工具,如mongoimport,而不是批量插入。
4). 批量插入中如果遇到错误,这个文档及之后的文档全部插入失败。可以使用continueOnError选项,忽略错误并且继续执行后续插入。
5). 当前版本MongoDB能收的最大消息长度是48M
6). 插入校验:主要验证有没有"_id",是否单条文档小于16M
2. 删除文档
1). 删除集合中的所有文档: db.foo.remove()
2). 删除符合条件的文档: db.mailing.llist.remove({"out":true})
3). 使用drop直接删除整个集合会更快: db.foo.drop。会删除索引等信息。
3. 更新文档
1). update更新:update有两个参数,第一个是查询文档,用于定位需要更新目标文档;另一个是修改器文档,用于说明要对找到的文档进行哪些修改。
2). 更新多个文档:默认情况下,更新只对符合匹配条件的第一个文档执行操作。要是有多个文档符合条件,只有第一个文档会被更新。要更新所有匹配的文档可以将update
第四个参数设置为true。update的默认行为以后可能会发生变化,会默认更新所有符合条件的文档,只有第四个参数设置为false才会只更新一个,所以建议每次都显式
表明要不要多文档更新。
3). 要想知道多文档更新到底更新了多少文档,可以运行getLastError命令。
4). 可以通过findAndMofify命令得到被更新的文档。返回的是修改之前的数据。findAndModify可以使用"update"键,也可以使用"remove"键。findAndMofify有很多可使用的字段:
findAndModify : 字符串,集合名
query : 检索文档的条件
sort : 排序结果条件
udpate : 用于对文档进行更新
remove : 表示是否删除文档,布尔类型
new : 布尔类型,表示返回更新前的文档还是更新后的文档。默认是更新前的文档。
fields : 文档需要返回的字段
upert : 布尔类型。值为true表示这是一个upsert。默认为false.
update 和 remove 必须有一个,也只能有一个。要是没有匹配的文档,这个命令会返回一个错误。
5). update可以有四个参数:
a. 第一个是查询文档,用于定位需要更新目标文档
b. 另一个是修改器文档,用于说明要对找到的文档进行哪些修改。
c. udpate的第三个参数是个upsert.要是没有找到符合更新条件的文档,就会以这个条件和更新文档为基础创建一个新的文档。如果找到,正常更新。默认为false。
d. 默认情况下,更新只对符合匹配条件的第一个文档执行操作。要是有多个文档符合条件,只有第一个文档会被更新。要更新所有匹配的文档可以将update第四个参数设置为true。
update的默认行为以后可能会发生变化,会默认更新所有符合条件的文档,只有第四个参数设置为false才会只更新一个,所以建议每次都显式表明要不要多文档更新。
4. 修改器:
1). $set : $set用来指定一个字段的值。如果这个字段不存在,则创建它 : db.users.update({"_id":ObjectId("***")},...{"$set":{"name":"lisi"}})
2). $unset : 将某个键完全删除
3). $inc :增加已有的键值,或者该键不存在那就创建一个。"$inc" 只能用于整型、长整型或双精度浮点型的值
4). $push : 向已有的数据末尾加一个元素,要是没有就创建一个。
5). $each : 使用$each子操作符,可以通过一次$push操作添加多个值
6). $slice : 将$slice和$push组合一起使用,这样就可以保证数组不会超过设定好的最大长度,这实际上就得到一个最多包含N个元素的数组。$slice得值必须是负整数,包含最后加入的N个元素。
7). $sort : 排序。注意,不能只将$slice或者$sort与$push 配合使用,必须和$each一起使用
8). $ne : 不重复
9). $addToSet : 避免往集合中插入的值重复。将$addToSet和$each组合起来,可以添加多个不同的值。与set属性类似
10). $pop : 从数组中删除元素。{"$pop":{"key":1}}从数组末尾删除一个元素,{"$pop":{"key":-1}} 从头部删除一个元素
11). $pull : 基于特定条件来删除元素,而不仅仅依据元素位置,这时可以使用$pull。$pull 会将所有匹配的元素删除。
12). 基于位置的数据修改器:通过位置或者定位操作符("$")。定位符只更新第一个匹配的元素。
13). 修改器的速度:$inc能就地修改,因为不需要改变文档的大小,只需要将键的值修改一下,所以非常快。而数据修改器可能会改变文档的大小,就会慢一些。
14). 填充因子:填充因子是MongoDB为每个文档预留的增长空间。
15). 移动文档非常慢。MongoDB必须将文档原先占用的空间释放掉,然后将文档写入另一片空间。
16). 如果你的模式在进行插入和删除时会进行大量的移动或者经常打乱数据,可以使用usePowerOf2Sizes选项以提高磁盘复用率。可以通过collMod命令来设定这个选项:
db.runCommond({"collMod":collectionName,"usePowerOf2Sizes":true})
这个集合之后进行所有空间分配时,得到的块大小都是2的幂。这个选项可能会导致初始空间分配不再那么高效。
17). upsert : 要是没有找到符合更新条件的文档,就会以这个条件和更新文档为基础创建一个新的文档。如果找到,正常更新。udpate的第三个参数表示这是个upsert.
db.analytics.update({"url":"/blog"},{"$inc":{"pageviews":1}},true)
这行代码更高效,并且是原子性的。
18). $setOnInsert : 只会在文档插入时设置字段的值。之后的所有更新操作中,这个字段的值都不会再改变了。
19). save shell 帮助程序:save 是一个shell函数,如果文档不存在,它会自动创建文档;如果文档存在,它就更新这个文档。
20). udpate 第一个参数是条件,第二个参数是更新内容,第三个参数表示没有符合条件的数据时,是创建还是不进行任何操作,第四个参数表示更新一个还是所有符合条件记录。
5. 写入安全机制
1). 默认情况下,插入、删除和更新会一直等待数据库响应(是否写入成功) ,然后才会继续执行。通常,遇到错误时,客户端会抛出一个异常。
2). 应答式写入是默认的方式:数据库给出响应,告诉你写入操作是否成功执行。非应答式写入不返回任何任何响应,所以无法知道写入是否成功。
3). shell 在执行非应答式写入后,会检查最后一个操作是否成功。可以调用getLastError手动强制在shell中进行检查,这一操作会检查最后一次操作中的错误。?
Mongodb 笔记02 创建、更新和删除文档的更多相关文章
-
MongoDB学习笔记二:创建、更新及删除文档
插入并保存文档 对目标集使用insert方法插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个&q ...
-
MongoDB学习笔记-创建、更新、删除文档
创建 MongoDB中使用insert方法来向集合插入文档,然后保存到MongoDB中. db.foo.insert({"hehe":"呵呵"} ...
-
创建、更新、删除文档。 --- Mongodb权威指南阅读。
插入文档: db.foo.insert({ "key" : "value"}); 使用insert插入一个数据,文档中如果没有_id 会自动给文档增加_id. ...
-
Elasticsearch 创建、更新、删除文档、处理冲突
----创建新文档---- 1._index,_type和_id的组合可以唯一标识一个文档,所以确保一个新文档的最简单的办法就是,使用索引请求的POST形式让elsticsearch自动生成唯一_id ...
-
Elasticsearch 索引、更新、删除文档
一.Elasticsearch 索引(新建)一个文档的命令: curl XPUT ' http://localhost:9200/test_es_order_index/test_es_order_t ...
-
MongoDB快速入门(八)- 删除文档
删除文档 MongoDB 的 remove()方法用于从集合中删除文档.remove()方法接受两个参数.一个是标准缺失,第二是justOne标志 deletion criteria : 根据文件(可 ...
-
MongoDb 创建、更新以及删除文档常用命令
mongodb由C++写就,其名字来自humongous这个单词的中间部分,从名字可见其野心所在就是海量数据的处理.关于它的一个最简洁描述为:scalable, high-performance, o ...
-
《mongoDB》基本操作-创建/更新/删除文档
一:基本操作 - db; 当前选择的集合(等于数据库名) > db demo - use db_name; 选择你要操作的集合 > use demo switched to db dem ...
-
MongoDB(二)创建更新删除文档
插入并保存文档操作 用insert向目标集合插入文档,如果没有_id键则会自动添加.最后自动保存. >db.foo.insert({"bar":"baz" ...
随机推荐
-
Zookeeper全解析——Paxos作为灵魂(转)
原计划在介绍完ZK Client之后就着手ZK Server的介绍,但是发现ZK Server所包含的内容实在太多,并不是简简单单一篇Blog就能搞定的.于是决定从基础搞起比较好. 那么ZK Serv ...
-
[CTSC 2012][BZOJ 2806]Cheat
真是一道好题喵~ 果然自动机什么的就是要和 dp 搞基才是王道有木有! A:连 CTSC 都叫我们搞基,果然身为一个程序猿,加入 FFF 团是我此生最明智的选择.妹子什么闪边去,大家一起来搞基吧! Q ...
-
session cookie 相结合实现
数据库配置文件 config.php <?php// config.php 数据库连接文件define('DB_HOST', 'localhost');define('DB_USER', 'ro ...
-
Swift - 自定义函数规则说明
1,无返回值的函数 1 2 3 func test(name:String){ } 2,返回一个返回值 1 2 3 func test(name:String) -> Bool{ r ...
-
自己动手写了第三阶段的处理器——教学OpenMIPS处理器蓝图
我们会继续上传新书<自己动手写处理器>(未公布).今天是第十条.我每星期试试4 从本章開始将一步一步地实现教学版OpenMIPS处理器.本章给出了教学版OpenMIPS的系统蓝图,首先介绍 ...
-
psql命令
原文:http://blog.csdn.net/smstong/article/details/17138355 psql# shell 环境下,查看当前所在的数据库的命令是: select cur ...
-
ELK+SpringBoot+Logback离线安装及配置
ELK+SpringBoot+Logback 离线安装及配置 版本 v1.0 编写时间 2018/6/11 编写人 xxx 目录 一. ELK介绍2 二. 安装环境2 三. Elasticse ...
-
python第七十七天---HTML
HTML5 :规则, 浏览器的通用规则 1.规则, 浏览器的通用规则 2.开发者: 学习html 规则 开发后台程序 - 写html文件 (当作模板) - 数据库获取数据,替换到指定的HTML文件中的 ...
-
nginx启用php
1. php下载https://secure.php.net/downloads.php搜索china镜像站点,从这里下载http://cn2.php.net/get/php-7.2.3.tar.gz ...
-
xgb 绘制
1.windows安装Graphviz2.38 安装地址:https://graphviz.gitlab.io/_pages/Download/Download_windows.html 2.在pyt ...