node学习(9)-- mongodb索引和explain

索引:

索引是对数据库表中一列或多列的值进行排序的一种结构,可以让我们查询数据库变得 更快

下面是创建索引的 命令:

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所耗费时间
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值