参考:菜鸟教程
『李兴华java培训23』MongoDB数据库
每个索引占据一定的存储空间,在进行插入,更新和删除操作时也需要对索引进行操作。所以,如果很少对集合进行读取操作,建议不使用索引。
由于索引是存储在内存(RAM)中,应该确保该索引的大小不超过内存的限制。
如果索引的大小大于内存的限制,MongoDB会删除一些索引,这将导致性能下降。
不应该在频繁更新的数据上面设置索引,会影响性能。
获得索引信息
db.collection.getIndexes()
查看student集合的索引情况
>db.student.getIndexes()
默认存在“_id”索引,1表示升序,名称为“id”(时间戳+机器码+PID+计数器)
由于 ObjectId 中存储了 4 个字节的时间戳,所以不需要为文档保存时间戳字段,可以通过 getTimestamp 函数来获取文档的创建时间:
>ObjectId("5bfa71f7beb3c7892f5f3c3a").getTimestamp()
在某些情况下,可能需要将ObjectId转换为字符串格式。你可以使用下面的代码:
>new ObjectId().str
查看集合索引大小
>db.col.totalIndexSize()
查看student集合的索引大小
>db.student.totalIndexSize()
单键索引
MongoDB Collection索引建立功能支持前台创建模式与后台创建模式两种。默认模式为前台创建模式。这种模式下会发生:DB被锁,主库所有读写被禁止、从