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个技巧汇总