mongodb index介绍

mongodb同其他数据一样,提供索引,来提高查询的效率。看下索引的种类:

1:基础索引

2:文档索引

3:组合索引

4:唯一索引

基础索引:

比如一个post集合中含有name字段,在name字段上建立索引:

db.post.ensureIndexe({name:1}) 后面的1意思是升序,-1表示降序

查询该集合的索引:

db.post.getIndexes();

会显示出索引的名字等等信息

如果在一个很大的字段上建立索引的话,那么就要注意,因为建立索引是很耗时间的,而且要锁住集合,不能写,所以建立大的索引要慎重,可以放在后台执行:

db.post.ensureIndexe({name:1},{backgroud:true})

删除索引:

db.post.dropIndexes() ----删除post上面所有索引

db.post.dropIndex({name:1}) ------删除指定的单个索引

文档索引:

也就是说字段可以是一个文档:

db.post.insert({name:"documents",address:{city:"hangzhou",stat:"HZ"}})

可以在address字段建议索引:

db.post.ensureIndexe({address:1})

那么我们在查询的时候就会用到这个索引:db.post.find({address:{city:"hangzhou",stat:"HZ"}})

但是如果db.post.find({address:{stat:"HZ",city:"hangzhou"}})则不走该索引,因为里面的顺序不一样。

组合索引:

post集合里面有name,和sga字段:

db.post.ensureIndex({name:1,age:1}) 这就是一个简单的组合索引

所以在以name为开始查询,或者排序都可以用到该索引 ,这里1或者-1主要关系到范围查询和排序的时候是否用到

唯一索引:

看个例子就明白,和其他数据库的性质一样,不能存在重复值

db.post.ensurIndex({name:1,age:1},{unique:true})

如果有重复的值,那么无法建立唯一索引,会报错:E11000

强制使用索引(hint)

> db.t5.insert({name: "zhanghaihong",age: 20})
> db.t5.ensureIndex({name:1, age:1})
> db.t5.find({age:{$lt:30}}).explain()

{
"cursor" : "BasicCursor",
"indexBounds" : [ ],
"nscanned" : 1,
"nscannedObjects" : 1,
"n" : 1,
"millis" : 0,
"allPlans" : [
{
"cursor" : "BasicCursor",
"indexBounds" : [ ] ----可以看到没有使用索引,此处没有任何东西
}
]
}

db.t5.find({age:{$lt:30}}).hint({name:1, age:1}).explain() ---红色部分强制使用索引

{
"cursor" : "BtreeCursor name_1_age_1",
"indexBounds" : [ ---使用了索引
[
{
"name" : {
"$minElement" : 1
},
"age" : -1.7976931348623157e+308
},
{
"name" : {
"$maxElement" : 1
},
"age" : 30
}
]
],
"nscanned" : 1,
"nscannedObjects" : 1,
"n" : 1,
"millis" : 0
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值