iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >【MongoDB学习笔记23】MongoDB的索引对象和数组
  • 949
分享到

【MongoDB学习笔记23】MongoDB的索引对象和数组

2024-04-02 19:04:59 949人浏览 泡泡鱼
摘要

mongoDB允许深入文档内部,对嵌套字段和数组建立索引;嵌套对象和数组字段可以和复合索引中的顶级字段一起使用,多数情况下与“正常”索引字段的行为也是一致的。 一、索引嵌套文档例如,集合中的文档如

mongoDB允许深入文档内部,对嵌套字段和数组建立索引;嵌套对象和数组字段可以和复合索引中的顶级字段一起使用,多数情况下与“正常”索引字段的行为也是一致的。

 

一、索引嵌套文档

例如,集合中的文档如下格式,

> db.post.findOne({"username":"sid"})   
{    
    "_id" : ObjectId("54aff7f43bd1048e7b585e39"),    
    "username" : "sid",    
    "loc" : {    
        "ip" : "1.2.3.4",    
        "city" : "springfield",    
        "state" : "ny"    
    }    
}    
>

需要在“loc”的city上建立索引来提高这个loc.city字段的查询速度:

> db.post.ensureIndex({"loc.city":1})   
{    
    "createdCollectionAutomatically" : false,    
    "numIndexesBefore" : 1,    
    "numIndexesAfter" : 2,    
    "ok" : 1    
}    
>

利用这种方式可以建立任意深度的索引,例如可以在X.Y.Z.A.B.C上建立索引。

但是,针对子文档“loc”上建立的索引,和建立在子文档的某个字段“loc.city”上的索引是不同的:

(1)对整个子文档上建立的索引,只会提高整个子文档的的查询速度;也就是说只有在完全匹配子文档的查询(包括字段顺序),子文档索引才会起作用;

(2)只有查询loc.city字段,索引loc.city才会起作用,其他情况索引loc.city不起作用;

 


二、数组上的索引

(1)可以看得出在数组字段上建立索引的代价比较大,因为每次的删除,更新都会对每一个索引进行刷新,太消耗服务器的资源;

(2)可以针对数组字段中的某一个元素做具体的单独索引,减少索引的数量;例如,在数组字段comments中的第九个元素中的votes上建立索引:

> db.post.ensureIndex({"comment.10.votes":1})

同样,只有精确匹配comment.10.votes查询,上述索引才会起到索引的作用。

 

三、多键索引

如果在数组字段上创建索引,那么这个索引称为多键索引( multikey)。

多键索引用explain函数中可以看到“isMultikey”字段的值为true,多键索引比非多键索引要慢一些;



您可能感兴趣的文档:

--结束END--

本文标题: 【MongoDB学习笔记23】MongoDB的索引对象和数组

本文链接: https://www.lsjlt.com/news/37800.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 【MongoDB学习笔记23】MongoDB的索引对象和数组
    MongoDB允许深入文档内部,对嵌套字段和数组建立索引;嵌套对象和数组字段可以和复合索引中的顶级字段一起使用,多数情况下与“正常”索引字段的行为也是一致的。 一、索引嵌套文档例如,集合中的文档如...
    99+
    2022-10-18
  • 【MongoDB学习笔记20】MongoDB的索引
    MongoDB的索引和关系型数据库的索引概念和功能是相同的:(1)不使用索引的搜索可以称为全表扫面,也就是说,服务器必须找完整个表才能查询整个结果;(2)建立索引后搜索,查询在索引中搜索,在索引的条目中找到...
    99+
    2022-10-18
  • 【MongoDB学习笔记27】MongoDB的TTL索引
    TTL索引(time-to-live index)允许为每一个文档设置一个超时时间,文档超过这个时间就会被删除。在ensureIndex中指定expireAfterSecs选项就可以创建一个TTL索引:&g...
    99+
    2022-10-18
  • 【MongoDB学习笔记21】MongoDB的复合索引
    索引的值是按照一定顺序排列的,因此使用索引键对文档进行搜索排序比较快;但是只有首先使用索引进行排序时,索引才有用;例如下面的排序里,“username”上的索引就没有起作用:> db.use...
    99+
    2022-10-18
  • 【MongoDB学习笔记22】MongoDB的索引管理
    使用ensureIndex函数创建集合的索引。对集合而言,每个索引只需要创建一次,重复创建没有任何作用;> show collections    s...
    99+
    2022-10-18
  • 【MongoDB学习笔记25】MongoDB的索引类型
    创建索引可以指定一些选项,使用不同的选项建立的索引会有不同的行为。 一、唯一索引唯一索引可以确保每一个文档的指定键都有唯一的值。例如,想确定文档中的username键不重复,创建一个唯一索引:&g...
    99+
    2022-10-18
  • 【MongoDB学习笔记24】MongoDB的explain和hint函数
    一、explain函数explain函数可以提供大量查询相关的信息,如果是慢查询,它最重要的诊断工具。例如:在有索引的字段上查询:> db.post.find({"loc.city":"ny...
    99+
    2022-10-18
  • 【MongoDB学习笔记17】MongoDB的查询:find中的数组查询
    db.post.find()    { "_id" : ObjectId("54a530c3ff0df3732bac1681"), "i...
    99+
    2022-10-18
  • 【MongoDB学习笔记12】深入MongoDB的更新(update)操作:数组修改
    查看一个文档的一个键值comments为一个数组[“test1”,”test2”]:> db.post.findOne({"id":1})    { ...
    99+
    2022-10-18
  • 对象是 ASP 函数学习笔记中的重要组成部分吗?
    在 ASP 中,对象是一个非常重要的概念,因为它们为开发人员提供了一种有效管理数据和应用程序的方式。在本文中,我们将探讨对象在 ASP 函数学习笔记中的重要性。 首先,让我们回顾一下 ASP 函数的基础知识。ASP 函数是一种可重用的代码...
    99+
    2023-10-10
    函数 学习笔记 对象
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作