4、创建、更新和删除文档(MongoDB笔记)

2017-06-05  本文已影响215人  yjaal

一、插入并保存文档

可以使用insert方法向目标集合插入一个文档:

> db.test.insert("bar" : "baz")

这个操作会给文档自动增加一个"_id"键(要是原来没有的话)。

1.1 批量插入

使用批量插入,可以将一组文档传递给数据库,使用insert函数实现批量插入:

1
注意:之前的批量插入函数batchInsert已经过时了。直接使用insert函数就可以。

只有需要将多个文档插入到一个集合时,这种方式才会有用。不能在单次请求中将多个文档批量插入到多个集合中。要是只导入原始数据(如,从MySQL中导入),可以使用命令行工具,如mongoimport,而不是批量插入。另一方面,可以使用批量插入在将数据存入MongoDB之前对数据做一个小的修改(如将日期转换为日期类型,或添加自定义的"_id"),这样批量插入也可以用于导入数据。

当前版本的MongoDB能接受的最大消息长度是48MB,所以在一次批量插入中能插入的文档是有限制的。如果试图插入48MB以上的数据,多数驱动程序会将这个批量插入的请求拆分为多个48MB的批量插入请求。

如果在执行批量插入的过程中有一个文档插入失败,那么在这个文档之前的所有文档都会成功插入到集合中,而这个文档及之后的所有文档全部插入失败。


2

1.2 插入校验

检查大小是一项基本结构检查:所有文档都必须小于16MB(这个值是MongoDB设计者人为定的,未来有可能会增加)。这个限制主要是为了防止不良的设计模式,并且保证性能一直。可以使用Object.bsonsize(doc)查看文档的BSON大小(单位为字节)。MongoDB只进行最基本的检查,所以插入非法数据很容易。主流语言的所有驱动程序都会在将数据库之前做大量的数据校验(比如文档是否过大,文档是否包含非UTF-8字符串)

二、删除文档

现在数据库中有些数据,要删除它:

> db.test.remove()

上述命令会删除test集合中的所有文档。但是不会删除集合本身,也不会删除集合的元信息。remove函数可以接受一个查询文档作为可选参数。给定这个参数以后,只有符合条件的文档才被删除。例如,假设要删除mailing.list集合中所有"opt-out"true的人:

> db.mailing.list.remove("opt-out" : true)

删除数据是永久的,不能撤销,也不能恢复。

2.1 删除速度

删除文档通常很快,但是如果要清空整个集合,那么使用drop直接删除集合会更快(然后在这个空集合上重建各项索引)。在删除大量数据时使用db.test.drop()代替removefindOne效率会更高,但是不能指定任何限定条件。结果是整个集合都被删除了,所有元数据也都不见了。

三、更新文档

文档存入数据库以后,就可以使用update方法来更新它。update有两个参数,一个是查询文档,用于定位需要更新的目的文档;另一个是修改器文档,用于说明要对找到的文档进行哪些修改。
未完待续。。。

上一篇下一篇

猜你喜欢

热点阅读