mongodb索引知识_动力节点Java学院整理
发布时间 - 2026-01-11 02:55:19 点击率:次我们日常做开发都避免不了要对程序进行性能优化,而程序的操作无非就是CURD,通常我们又会花费50%的时间在R上面,因为Read操作对用户来说是非常敏感的,处理不好就会被人唾弃。

从算法上来说有5种经典的查找,具体的可以参见我的算法速成系列,这其中就包括我们今天所说的“索引查找”,如果大家对mysql比较了解的话,相信索引查找能给我们带来什么样的性能提升吧。
我们首先插入10w数据,上图说话:
一:性能分析函数(explain)
好了,数据已经插入成功,既然我们要做分析,肯定要有分析的工具,幸好mongodb中给我们提供了一个关键字叫做“explain",那么怎么用呢?
还是看图,注意,这里的name字段没有建立任何索引,这里我就查询一个“name10000”的姓名。
仔细看红色区域,有几个我们关心的key。
cursor: 这里出现的是”BasicCursor",什么意思呢,就是说这里的查找采用的是“表扫描”,也就是顺序查找,很悲催啊。
nscanned: 这里是10w,也就是说数据库浏览了10w个文档,很恐怖吧,这样玩的话让人受不了啊。
n: 这里是1,也就是最终返回了1个文档。
millis: 这个就是我们最最最....关心的东西,总共耗时114毫秒。
二:建立索引(ensureIndex)
在10w条这么简单的集合中查找一个文档要114毫秒有一点点让人不能接收,好,那么我们该如何优化呢?mongodb中给我们带来了索引查找,看看能不能让我们的查询一飞冲天.....
这里我们使用了ensureIndex在name上建立了索引。”1“:表示按照name进行升序,”-1“:表示按照name进行降序。
我的神啊,再来看看这些敏感信息。
cursor: 这里出现的是”BtreeCursor",这么牛X,mongodb采用B树的结构来存放索引,索引名为后面的“name_1"。
nscanned: 数据库只浏览了一个文档就OK了。
n: 直接定位返回。
millis: 看看这个时间真的不敢相信,秒秒杀。
通过这个例子相信大家对索引也有了感官方面的认识了吧。
三:唯一索引
和sqlserver一样都可以建立唯一索引,重复的键值自然就不能插入,在mongodb中的使用方法是:
db.person.ensureIndex({"name":1},{"unique":true})
四:组合索引
有时候我们的查询不是单条件的,可能是多条件,比如查找出生在‘1989-3-2'名字叫‘jack'的同学,那么我们可以建立“姓名”和"生日“的联合索引来加速查询。
看到上图,大家或者也知道name跟birthday的不同,建立的索引也不同,升序和降序的顺序不同都会产生不同的索引,那么我们可以用getindexes来查看下person集合中到底生成了那些索引。
此时我们肯定很好奇,到底查询优化器会使用哪个查询作为操作,呵呵,还是看看效果图:
看完上图我们要相信查询优化器,它给我们做出的选择往往是最优的,因为我们做查询时,查询优化器会使用我们建立的这些索引来创建查询方案,如果某一个先执行完则其他查询方案被close掉,这种方案会被mongodb保存起来,当然如果非要用自己指定的查询方案,这也是可以的,在mongodb中给我们提供了hint方法让我们可以暴力执行。
五: 删除索引
可能随着业务需求的变化,原先建立的索引可能没有存在的必要了,可能有的人想说没必要就没必要呗,但是请记住,索引会降低CUD这三种操作的性能,因为这玩意需要实时维护,所以啥问题都要综合考虑一下,这里就把刚才建立的索引清空掉来演示一下:dropIndexes的使用。
总结
以上所述是小编给大家介绍的mongodb索引知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# mongodb索引
# Java中EnumMap代替序数索引代码详解
# Java应用开源框架实现简易web搜索引擎
# Java使用分治算法实现排序数索引功能示例【二分搜索】
# Java使用强大的Elastisearch搜索引擎实例代码
# JAVA实现空间索引编码——GeoHash的示例
# java实现简单的搜索引擎
# java编程实现根据EXCEL列名求其索引的方法
# java多线程处理执行solr创建索引示例
# Java数组索引异常产生及解决方案
# 的是
# 给我们
# 升序
# 文档
# 让人
# 让我们
# 上图
# 小编
# 有一
# 我就
# 就会
# 好了
# 降序
# 都要
# 在此
# 被人
# 要有
# 可以用
# 我们可以
# 就没
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
活动邀请函制作网站有哪些,活动邀请函文案?
*服务器网站为何频现安全漏洞?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
图册素材网站设计制作软件,图册的导出方式有几种?
如何用已有域名快速搭建网站?
Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
详解Oracle修改字段类型方法总结
微信小程序 五星评分(包括半颗星评分)实例代码
今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】
Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理
深圳网站制作的公司有哪些,dido官方网站?
如何注册花生壳免费域名并搭建个人网站?
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
敲碗10年!Mac系列传将迎来「触控与联网」双革新
Laravel如何处理异常和错误?(Handler示例)
Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】
Laravel如何与Pusher实现实时通信?(WebSocket示例)
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
Laravel如何使用模型观察者?(Observer代码示例)
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理
中国移动官方网站首页入口 中国移动官网网页登录
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
免费网站制作appp,免费制作app哪个平台好?
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
高防服务器:AI智能防御DDoS攻击与数据安全保障
Laravel定时任务怎么设置_Laravel Crontab调度器配置
如何用虚拟主机快速搭建网站?详细步骤解析
Laravel如何优化应用性能?(缓存和优化命令)
昵图网官网入口 昵图网素材平台官方入口
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
Laravel如何使用Service Container和依赖注入?(代码示例)
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】
Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全
微信公众帐号开发教程之图文消息全攻略
简历没回改:利用AI润色让你的文字更专业
大型企业网站制作流程,做网站需要注册公司吗?
jQuery中的100个技巧汇总

