mongodb----索引查询与建立

循环插入数据

for(i=0;i<500000;i++){db.test.insert({name:'liangqicong'+i,age:i})}

 

查询有多少条数据

db.test.count()

 

慢查询配置

db.getProfilingStatus()

{ "was" : 0, "slowms" : 100, "sampleRate" : 1 }  #这里表示超过100毫秒的查询就会记录在mongodb.log这个日志里面

 

执行查询语句

db.test.find({age:9999})

查看日志,可以看到执行了161毫秒

2019-02-16T11:59:51.118+0800 I COMMAND  [conn1] command liangqicong.test appName: "MongoDB Shell" command: find { find: "test", filter: { age: 9999.0 }, lsid: { id: UUID("5cd66bb1-dfec-4f6e-860a-b44bc97a2dce") }, $db: "liangqicong" } planSummary: COLLSCAN keysExamined:0 docsExamined:500000 cursorExhausted:1 numYields:3909 nreturned:1 reslen:169 locks:{ Global: { acquireCount: { r: 3910 } }, Database: { acquireCount: { r: 3910 } }, Collection: { acquireCount: { r: 3910 } } } protocol:op_msg 161ms

 

查看查询语句的性能

db.test.find({age:9999}).explain(true)

其中会有显示

"executionStats" : {
"executionSuccess" : true,
"nReturned" : 1,
"executionTimeMillis" : 157,
"totalKeysExamined" : 0,
"totalDocsExamined" : 500000,               #总共扫描了500000
"executionStages" : {
"stage" : "COLLSCAN",                           #这里是表示全表查询
"filter" : {
"age" : {
"$eq" : 9999
}
},

因为是全表查询模式,而且扫描了500000行,因此会很慢。

 

查看表里面有什么索引

> db.test.getIndexes()
[
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "liangqicong.test"
}
]

 

为age字段添加索引

db.test.ensureIndex({age:1})  (升序)

删除索引

db.test.dropIndex({age:1})

 

如果用正则去搜索数据的话,索引是无效的。

 

mongodb建立唯一索引

db.test.ensureIndex({userid:1},{unique:true})

这样,userid就一定是唯一的,跟主键差不多。

 

posted @ 2019-02-17 09:58  喜欢it的小聪聪  阅读(469)  评论(0编辑  收藏  举报