Mongodb使用索引进行查询优化的操作方法

 更新时间:2024年06月28日 10:36:14   作者:威赞  
为集合建立合适的索引,能够有效的减少查询操作时扫描数据的数量 ,从而提高查询效率,简化了mongodb内部查询工作,这篇文章主要介绍了Mongodb使用索引进行查询优化的操作方法,需要的朋友可以参考下

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第80篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。如果您认为我的文章对您有帮助或者解决您的问题,欢迎在文章下面点个赞,或者关注威赞。谢谢。

前面的文档当中,我们重点介绍了mongodb数据更新update中各种各样的操作符。有兴趣的小伙伴们可以查看本专栏里的相关文章。这篇文章,结合官方文档,探讨一下使用索引进行查询优化。

概述

为集合建立合适的索引,能够有效的减少查询操作时扫描数据的数量 ,从而提高查询效率,简化了mongodb内部查询工作。如原来的某个查询需要进行全表扫描。当集合中有1000条数据时,可能需要逐一扫描这1000条数据,才可以返回查询结果。而当为查询字段添加索引后,通过索引,直接定位到查询结果,可能会极大的减少扫描文档数据的数量。

为读取操作添加索引

当用户建立查询语句,计划通过指定字段或几个字段查询数据时,在指定字段的索引或者几个字段的复合索引能够避免对集合进行全表扫描。

如一个针对表inventory的查询,要求使用字段type作为过滤条件,type是用户指定的一个数值

var typeValue = <someUserInput>;
db.inventory.find( {type: typeValue});

为了提高这个针对集合inventory查询的性能,在集合inventory创建一个type字段的索引。使用db.collection.createIndex()方法创建。这个索引,能够避免查询整个集合来返回数据。

db.inventory.createIndex({type: 1})

用户可以通过分析执行计划,来确定mongodb是否使用当前索引。

除了提高查询效率以外,索引还可以改善排序操作的效率并能够提过存储空间使用率。

查询操作过滤度

查询操作过滤度表示了查询操作中使用的过滤词排除或者过滤文档的优良程度。查询操作过滤度能够决定该查询是否使用索引。高过滤度查询,能够匹配出更小范围的文档数据。如针对_id字段等等值查询就具备非常高的查询操作过滤度。它几乎可以匹配到唯一的文档数据。相反,低过滤度的查询会匹配集合中更多百分比的数据,几乎不能使用索引。

例如不等操作$nin和$ne就不是高过滤度查询操作,这两个查询操作经常会匹配到集合中大部分的数据。因此在大多数查询当中,带有$nin和$ne操作的查询,使用索引查询效率,不会比全表扫描高多少。

而对于正则表达式的查询过滤度,还与正则表达式本身相关。

索引覆盖查询

索引覆盖查询只完全通过索引过滤数据并且使用索引中的字段来返回结果而不需要查询文档数据的查询。同时满足下面三个条件,就可以所该索引覆盖了查询

  • 查询中所有查询字段都是索引的一部分
  • 查询返回字段也包含在该索引当中
  • 查询当中过滤字段没有对null的过滤(如{"field": null}或者{"field": {$eq: null}})。

例如在集合inventory中创建字段type和item的索引

db.inventory.createIndex({type: 1, item:1})

该索引覆盖了下面的查询操作。只通过type和item字段过滤数据,只返回item字段

db.inventory.find(
    {type:"food", item: /^c/},
    {item:1, _id:0}
)

因为该索引中并不包含_id字段,因此查询返回字段中,需要显示的把_id字段排除。

嵌入式文档索引覆盖查询

同样,索引覆盖查询也适用于嵌入式文档。例如,集合userdata中有下面的数据

{ _id:1, user: { login: "tester"}}

为该集合建立索引

db.userdata.createIndex({"user.login":1})

该索引可以覆盖下面的查询

db.userdata.find( {"user.login": "tester"}, {"user.login": 1, _id: 0})

多键索引覆盖查询

多键索引能够覆盖针对索引中非数组字段的查询。不能覆盖带有数组字段的查询。

索引覆盖查询性能

因为索引当中已经包含了查询中所需要的所有字段和返回字段 ,mongodb可以只通过索引返回查询结果。只通过索引的查询效率,比其他任何索引外查询的效率都要高。因为索引通常保存在内存当中或顺序的保存在磁盘上,而且会比索引依赖的文档小。

索引查询优化限制

  • 地理信息索引不支持索引覆盖查询
  • 多键查询不能覆盖带有数组字段的查询
  • 在分片集中,包含分片key的索引才能支持索引覆盖查询

当然用户可以查看执行计划,确当该查询是否是索引覆盖查询。

到此这篇关于Mongodb使用索引进行查询优化的文章就介绍到这了,更多相关Mongodb索引内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mongoose find 查询返回json数据处理方式

    Mongoose find 查询返回json数据处理方式

    这篇文章主要介绍了Mongoose find 查询返回json数据处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Mongodb聚合函数count、distinct、group如何实现数据聚合操作

    Mongodb聚合函数count、distinct、group如何实现数据聚合操作

    Mongodb中自带的基本聚合函数有三种:count、distinct和group。下面我们分别来讲述一下这三个基本聚合函数及如何实现数据聚合操作,感兴趣的朋友一起学习吧
    2016-05-05
  • MongoDB查询技巧总结

    MongoDB查询技巧总结

    这篇文章主要介绍了MongoDB查询技巧总结,例如AND、OR条件查询,子文档查询等,需要的朋友可以参考下
    2014-05-05
  • MongoDB实现查询、分页和排序操作以及游标的使用

    MongoDB实现查询、分页和排序操作以及游标的使用

    本文详细讲解了MongoDB实现查询、分页和排序操作以及游标的使用方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • MongoDB快速入门及其SpringBoot实战教程

    MongoDB快速入门及其SpringBoot实战教程

    MongoDB是一个开源、高性能、无模式的文档型数据库,当初的设计就是用于简化开发和方便扩展,是NoSQL数据库产品中的一种,它支持的数据结构非常松散,是一种类似于JSON的格式叫BSON,本文介绍MongoDB快速入门及其SpringBoot实战,感兴趣的朋友一起看看吧
    2023-12-12
  • mongodb的写操作

    mongodb的写操作

    今天小编就为大家分享一篇关于mongodb的写操作,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • mongodb运维_动力节点Java学院整理

    mongodb运维_动力节点Java学院整理

    这篇文章主要介绍了mongodb运维的相关知识,非常不错,具有参考借鉴价值,需要的的朋友参考下吧
    2017-08-08
  • Mongodb 数据类型及Mongoose常用CURD

    Mongodb 数据类型及Mongoose常用CURD

    MongoDB 是一个开源的 NoSQL 数据库,相比 MySQL 那样的关系型数据库,它更为轻巧、灵活,非常适合在数据规模很大、事务性不强的场合下使用,本文给大家介绍Mongodb 数据类型及Mongoose常用CURD,感兴趣的朋友一起学习吧
    2016-01-01
  • MongoDB分组查询和聚合查询实例教程

    MongoDB分组查询和聚合查询实例教程

    聚合(aggregate)是MongoDB的高级查询语言,它允许我们通过转化合并多个文档的数据来生成新的在单个文档里不存在的文档信息,下面这篇文章主要给大家介绍了关于MongoDB分组查询和聚合查询的相关资料,需要的朋友可以参考下
    2023-05-05
  • MongoDB和mysql的区别对比分析

    MongoDB和mysql的区别对比分析

    MongoDB 是一个基于分布式文件存储的数据库,而MySQL 是一款安全、跨平台、高效的,并与 PHP、Java 等主流编程语言紧密结合的数据库系统,本文重点给大家介绍MongoDB和mysql的区别,需要的朋友可以参考下
    2023-01-01

最新评论