博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MongoDB(三):创建、更新及删除文档
阅读量:7049 次
发布时间:2019-06-28

本文共 1155 字,大约阅读时间需要 3 分钟。

hot3.png

插入并保存文档

> db.foo.insert({"hello": "world"})

如果要插入多个文档,使用批量插入会快一些。因为一次的批量插入只是单个的TCP请求,无需处理大量的消息头,这样能够减少插入时间。单个文档发送至数据库时,会有一个头部消息,告诉数据库对指定的集合做插入操作。用批量插入的话,数据库就不用多次处理每一个文档的这种头部信息。

删除文档

> db.users.remove()

上述命令会删除users集合中所有的文档。remove函数可以接受一个查询文档作为可选参数,如:
> db.users.remove({"name": "Tom"})
删除文档的速度通常会很快,但是要清除整个集合,直接删除整个集合(然后重建索引),速度会快得多。

更新文档

原文档:

{"_id": ObjectId("4b3a32sf23skskd", "name": "joe", "friends": 32, "eneimes": 2)}
目标文档:
{"_id": ObjectId("4b3a32sf23skskd", “username”: "joe", "relationships": {"friends": 32, "eneimes": 2}}
使用update来替换文档:
> var joe = db.users.findOne({"name": "joe"});
> joe.relationships = {"friends": 32, "eneimes": 2};
{
    "friends": 32,
    "eneimes": 2
}
> joe.username = joe.name;
"joe"
> delete joe.friends;
true
> delete joe.eneimes;
true
> delete name;
true
> db.users.update({"name": "joe"}, joe);
常见的错误:查询条件匹配了多个文档,然后更新的时候由于第二个参数的存在就产生重复的"_id"的值。数据库会报错,不做任何修改。为了避免这种情况,最好确保更新总是指定唯一文档,例如通过像"_id"这样的键来匹配。
对文档进行部分更新,可以使用原子的更新修改器。如"$set"修改器、"$inc"修改器等等。具体可查看。

瞬间完成

插入、删除和更新都是瞬间完成的,因为它们都不需要等待数据库响应。这并不是异步操作,类似UDP的不可靠特性,客户端将文档发送给服务器后就立刻干别的了。客户端永远都不会收到各种响应。

优点:速度快,只受客户端发送的速度和网络速度的制约。

转载于:https://my.oschina.net/ckanner/blog/87071

你可能感兴趣的文章
struts spring整合出错
查看>>
JSP 基础(一)
查看>>
LeetCode 905. Sort Array By Parity
查看>>
oracle数据库的常见数据类型
查看>>
UESTC #1919 一棵复杂的线段树
查看>>
(九)软件测试人员定位
查看>>
CSS 笔记
查看>>
Docker for windows部署mysql挂载数据卷
查看>>
Web APi之认证(Authentication)两种实现方式【二】(十三)
查看>>
SqlServer中用SQL语句附加数据库及修改数据库逻辑文件名
查看>>
0621 第三次冲刺
查看>>
字节单位换算
查看>>
Win7开自带的虚拟WIFI
查看>>
EFT开发注意事项
查看>>
_CRT_SECURE_NO_WARNINGS
查看>>
python练习-登陆三次锁定
查看>>
PLSQL安装资料
查看>>
java LinkedList的使用方法介绍
查看>>
android学习路线
查看>>
Python Pandas 箱线图
查看>>