MongoDB实战(7)索引与性能

php中文网
发布: 2016-06-07 17:37:54
原创
1025人浏览过

一、索引MongoDB提供了多样性的索引支持索引信息被保存在system.indexes中且默认总是为_id创建索引。1、基础索引在字段age上创建索引1(升序);-1(降序)上例显示出

一、索引

MongoDB提供了多样性的索引支持索引信息被保存在system.indexes中且默认总是为_id
创建索引。

1、基础索引

在字段age上创建索引1(升序);-1(降序)

210820993.png

上例显示出来的一共有2个索引其中_id是创建表的时候自动创建的索引此索引是不能
够删除的。

当系统已有大量数据时创建索引就是个非常耗时的活我们可以在后台执行只需指定
“backgroud:true”即可。

db.stu.ensureIndex({age:1},{background:1})

2、文档索引

索引可以任何类型的字段甚至文档

db.stu.insert({_id:3,name:'user2',age:12,addr:{city:'beijing',state:"BJ"}}) db.stu.insert({_id:4,name:'user2',age:12,addr:{city:'shanghai',state:"SH"}}) db.stu.ensureIndex({addr:1})

下面这个查询将会用到我们刚刚建立的索引

db.stu.find({addr:{city:'beijing',state:'BJ'}}) "_id" : 3, "name" : "user2", "age" : 12, "addr" : { "city" : "beijing", "state" : "BJ" } }

而下面的查询却不能查到结果

db.stu.find({addr:{state:'BJ',city:'beijing'}})

212140619.png

3、组合索引

跟其它数据库产品一样MongoDB也是有组合索引的下面我们将在addr.city和addr.state
上建立组合索引。当创建组合索引时字段后面的1表示升序-1表示降序是用1还是
用-1主要是跟排序的时候或指定范围内查询的时候有关的。

db.stu.ensureIndex({'addr.city':1,'addr.state':1})

下面的查询都用到了这个索引

212851985.png

212924322.png

4、唯一索引

只需在ensureIndex命令中指定”unique:true”即可创建唯一索引。

db.t4.ensureIndex({firstname: 1, lastname: 1}, {unique: true});

当建唯一索引时如果表中有2条一模一模的数据就建立不了唯一索引。

5、强制使用索引

hint命令可以强制使用某个索引。

db.stu.ensureIndex({name:1,age:1})

则下面不能使用索引

知海图Chat
知海图Chat

知乎与面壁智能合作推出的智能对话助手

知海图Chat 157
查看详情 知海图Chat

213742108.png

使用hint强制使用索引

213851912.png

6、删除索引

#删除t3 表中的所有索引 db.t3.dropIndexes() #删除t4 表中的firstname 索引 db.t4.dropIndex({firstname: 1})

二、explain执行计划

MongoDB提供了一个explain命令让我们获知系统如何处理查询请求。利用explain命令
我们可以很好地观察系统如何使用索引来加快检索同时可以针对性优化索引。

几个关键的字段说明:
cursor:返回游标类型(BasicCursor或BtreeCursor)
nscanned:被扫描的文档数量
n:返回的文档数量
millis:耗时(毫秒)
indexBounds:所使用的索引

三、优化器profile

在MySQL中慢查询日志是经常作为我们优化数据库的依据那在MongoDB中是否有类似
的功能呢?答案是肯定的那就是MongoDBDatabaseProfiler。所以MongoDB不仅有而且
还有一些比MySQL的SlowQueryLog更详细的信息。

1、开启Profiling功能

有两种方式可以控制Profiling的开关和级别第一种是直接在启动参数里直接进行设置。
启动MongoDB时加上–profile=级别即可。
也可以在客户端调用db.setProfilingLevel(级别)命令来实时配置Profiler信息保存在
system.profile中。我们可以通过db.getProfilingLevel()命令来获取当前的Profile级别。

profile的级别可以取012三个值他们表示的意义如下
0–不开启
1–记录慢命令(默认为>100ms)
2–记录所有命令

214829974.png

Profile记录在级别1时会记录慢命令那么这个慢的定义是什么?上面我们说到其默认为
100ms当然有默认就有设置其设置方法和级别一样有两种一种是通过添加–slowms启
动参数配置。第二种是调用db.setProfilingLevel时加上第二个参数

db.setProfilingLevel(1,10);

2、查询Profiling记录

与MySQL的慢查询日志不同MongoDBProfile记录是直接存在系统db里的记录位置
system.profile所以我们只要查询这个Collection的记录就可以获取到我们的Profile记
录了。列出执行时间长于某一限度(5ms)的Profile记录

db.system.profile.find( { millis : { $gt : 5 } } )
相关标签:
数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号