索引:
索引是对数据库表中一列或多列的值进行排序的一种结构,可以让我们查询数据库变得 更快
下面是创建索引的 命令:
db.user.ensureIndex( {"username":1})
获取当前集合的索 引:
db.user.getIndexes()
删除索引的命令是 :
db.user.dropIndex( {"username":1})
复合索引:
数字 1 表示 username 键的索引按升序存储,-1 表示 age 键的索引按照降序方式存储
db.user.ensureIndex({"username":1, "age":-1})
该索引被创建后,基于 username 和 age 的查询将会用到该索引,或者是基于 username 的查询也会用到该索引,但是只是基于 age 的查询将不会用到该复合索引
唯一索引:
db.user.ensureIndex( {"useri d":1},{"uniq ue":true})
如果再次插入 userid 重复的文档时,MongoDB 将报错,以提示插入重复键
db.user.insert({"userid":5})
db.user.insert({"userid":5}) // E11000 duplicate key error index: user.user.$userid_1 dup key: { : 5.0 }
如果插入的文档中不包含 userid 键,那么该文档中该键的值为 null,如果多次插入类似 的文档,MongoDB 将会报出同样的错误,如:
db.user.insert({"userid1":5})
db.user.insert({"userid1":5}) //E11000 duplicate key error index: user.user.$userid_1 dup key: { : null }
explain 是非常有用的工具,会帮助你获得查询方面诸多有用的信息
db.tablename.find().explain( "executionStats" )
关注输出的如下数值:explain.executionStats.executionTimeMillis所耗费时间