一、插入并保存文档
可以使用insert
方法向目标集合插入一个文档:
> db.test.insert("bar" : "baz")
这个操作会给文档自动增加一个"_id"
键(要是原来没有的话)。
1.1 批量插入
使用批量插入,可以将一组文档传递给数据库,使用insert
函数实现批量插入:
注意:之前的批量插入函数
batchInsert
已经过时了。直接使用insert
函数就可以。
只有需要将多个文档插入到一个集合时,这种方式才会有用。不能在单次请求中将多个文档批量插入到多个集合中。要是只导入原始数据(如,从MySQL
中导入),可以使用命令行工具,如mongoimport
,而不是批量插入。另一方面,可以使用批量插入在将数据存入MongoDB
之前对数据做一个小的修改(如将日期转换为日期类型,或添加自定义的"_id"
),这样批量插入也可以用于导入数据。
当前版本的MongoDB
能接受的最大消息长度是48MB
,所以在一次批量插入中能插入的文档是有限制的。如果试图插入48MB
以上的数据,多数驱动程序会将这个批量插入的请求拆分为多个48MB
的批量插入请求。
如果在执行批量插入的过程中有一个文档插入失败,那么在这个文档之前的所有文档都会成功插入到集合中,而这个文档及之后的所有文档全部插入失败。
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()
代替remove
和findOne
效率会更高,但是不能指定任何限定条件。结果是整个集合都被删除了,所有元数据也都不见了。
三、更新文档
文档存入数据库以后,就可以使用update
方法来更新它。update
有两个参数,一个是查询文档,用于定位需要更新的目的文档;另一个是修改器文档,用于说明要对找到的文档进行哪些修改。
未完待续。。。