上篇文章中我们介绍了 MongoDB 中索引的简单操作,创建、查看、删除等基本操作,不过上文我们只介绍了一种类型的索引,本文我们来看看其他类型的索引。

文章目录

  • 一、_id 索引
  • 二、复合索引
  • 三、过期索引
  • 四、全文索引
  • 五、地理空间索引
    • 1. 2d 索引
    • 2. 2d sphere 索引
  • 六、复合地理空间索引

一、_id 索引

我们在上文介绍过,我们往集合中添加文档时,默认情况下MongoDB都会帮助我们创建一个名为_id的字段,这个字段就是一个索引。默认情况下,一般的集合都会帮我们创建这个字段作为索引,但也有一些集合不会将_id默认作为索引,比如固定集合,这个我们后面的文章会详细说到这个问题。

二、复合索引

如果我们的查询条件有多个的话,我们可以对这多个查询条件都建立索引,比如我们可以对文档中的x和y字段都建立索引,如下:

db.sang_collect.ensureIndex({x:1,y:-1})

此时执行如下查询语句时就会用到这个复合索引:

db.sang_collect.find({x:1,y:999})

小伙伴们也可以通过查看查询计划来确定确实使用到了上文创建好的索引。

三、过期索引

顾名思义,过期索引就是一种会过期的索引,在索引过期之后,索引对应的数据会被删除,创建方式如下:

db.sang_collect.ensureIndex({time:1},{expireAfterSeconds:30})

expireAfterSeconds表示索引的过期时间,单位为秒。time表示索引的字段,time的数据类型必须是ISODate或者ISODate数组,否则的话,当索引过期之后,time的数据就不会被删除。

四、全文索引

全文索引虽然好用,可惜不支持中文,我们这里就先做一个简单的了解。

比如,我的数据集如下:

{"_id" : ObjectId("59f5a3da1f9e8e181ffc3189"),"x" : "Java C# Python PHP"
}
{"_id" : ObjectId("59f5a3da1f9e8e181ffc318a"),"x" : "Java C#"
}
{"_id" : ObjectId("59f5a3da1f9e8e181ffc318b"),"x" : "Java Python"
}
{"_id" : ObjectId("59f5a3da1f9e8e181ffc318c"),"x" : "PHP Python"
}
{"_id" : ObjectId("59f5a4541f9e8e181ffc318d"),"x" : "C C++"
}

我们可以给x字段建立一个全文索引,创建方式如下:

db.sang_collect.ensureIndex({x:"text"})

MongoDB会自动对x字段的数据进行分词,然后我们就可以通过如下语句进行查询:

db.sang_collect.find({$text:{$search:"Java"}})

此时x中包含Java的文档都会被查询出来。如果想查询既包含Java又包含C#的文档,操作如下:

db.sang_collect.find({$text:{$search:"\"Java C#\""}})

用一对双引号将查询条件括起来,如果想查询包含PHP或者Python的文档,操作如下:

db.sang_collect.find({$text:{$search:"PHP Python"}})

如果想查询既有PHP,又有Python,但是又不包括Java的文档,如下:

db.sang_collect.find({$text:{$search:"PHP Python -Java"}})

建立了全文索引之后,我们也可以查看查询结果的相似度,使用$meta,如下:

db.sang_collect.find({$text:{$search:"PHP Python"}},{score:{$meta:"textScore"}})

此时查询结果中会多出一个score字段,该字段的值越大,表示相似度越高,我们可以根据score利用sort来对其进行排序,如下:

db.sang_collect.find({$text:{$search:"PHP Python"}},{score:{$meta:"textScore"}}).sort({score:{$meta:"textScore"}})

全文索引目前看起来功能还是很强大,可惜暂时不支持中文,不过网上对此也有很多解决方案,小伙伴们可以自行搜索查看。

五、地理空间索引

1. 2d 索引

2d索引,可以用来存储和查找平面上的点。,2d索引一般我们可以用在游戏地图中

向集合中插入一条记录点的数据:

db.sang_collect.insert({x:[90,0]})

插入数据的格式为[经度,纬度],取值范围,经度[-180,180],纬度[-90,90]。数据插入成功之后,我们先通过如下命令创建索引:

db.sang_collect.ensureIndex({x:"2d"})

然后通过$near我们可以查询某一个点附近的点,如下:

db.sang_collect.find({x:{$near:[90,0]}})

默认情况下返回该点附近100个点,我们可以通过$maxDistance来设置返回的最远距离:

db.sang_collect.find({x:{$near:[90,0],$maxDistance:99}})

我们也可以通过$geoWithin查询某个形状内的点,比如查询矩形中的点:

db.sang_collect.find({x:{$geoWithin:{$box:[[0,0],[91,1]]}}})

两个坐标点用来确定矩形的位置。

查询圆中的点:

db.sang_collect.find({x:{$geoWithin:{$center:[[0,0],90]}}})

参数分别表示圆的圆心和半径。

查询多边形中的点:

db.sang_collect.find({x:{$geoWithin:{$polygon:[[0,0],[100,0],[100,1],[0,1]]}}})

这里可以填入任意多个点,表示多边形中的各个点。

2. 2d sphere 索引

2dsphere适用于球面类型的地图,它的数据类型是GeoJSON格式的,我们可以在http://geojson.org/地址上查看GeoJSON格式的样式,比如我们描述一个点,GeoJSON如下:

{"_id" : ObjectId("59f5e0571f9e8e181ffc3196"),"name" : "shenzhen","location" : {"type" : "Point","coordinates" : [ 90.0, 0.0]}
}

描述线,GeoJSON格式如下:

{"_id" : ObjectId("59f5e0d01f9e8e181ffc3199"),"name" : "shenzhen","location" : {"type" : "LineString","coordinates" : [ [ 90.0, 0.0], [ 90.0, 1.0], [ 90.0, 2.0]]}
}

描述多边形,GeoJSON格式如下:

{"_id" : ObjectId("59f5e3f91f9e8e181ffc31d0"),"name" : "beijing","location" : {"type" : "Polygon","coordinates" : [ [ [ 0.0, 1.0], [ 0.0, 2.0], [ 1.0, 2.0], [ 0.0, 1.0]]]}
}

还有其他的类型,具体小伙伴们可以参考http://geojson.org/。有了数据之后,我们可以通过如下操作来创建地理空间索引了:

db.sang_collect.ensureIndex({location:"2dsphere"})

比如我想查询和深圳这个区域有交集的文档,如下:

var shenzhen = db.sang_collect.findOne({name:"shenzhen"})
db.sang_collect.find({location:{$geoIntersects:{$geometry:shenzhen.location}}})

这里的查询结果是和深圳这个区域有交集的都会查到(比如经过深圳的高速公路、铁路等),我们也可以只查询深圳市内的区域(比如深圳市内所有的学校),如下:

var shenzhen = db.sang_collect.findOne({name:"shenzhen"})
db.sang_collect.find({location:{$within:{$geometry:shenzhen.location}}})

也可以查询腾讯附近的其他位置,如下:

var QQ = db.sang_collect.findOne({name:"QQ"})
db.sang_collect.find({location:{$near:{$geometry:QQ.location}}})

六、复合地理空间索引

位置往往只是我们查询的一个条件,比如我要查询深圳市内所有的学校,那我得再增加一个查询条件,如下:

var shenzhen = db.sang_collect.findOne({name:"shenzhen"})
db.sang_collect.find({location:{$within:{$geometry:shenzhen.location}},name:"QQ"})

其他的查询条件跟在后面就行了。

一篇文章带你学习 MongoDB 中各种类型的索引(_id索引/复合索引/过期索引/全文索引/地理空间索引/复合地理空间索引)相关推荐

  1. css 科技 边框_一篇文章带你学习CSS3图片边框

    这篇文章我们来讲一下在网站建设中,一篇文章带你学习CSS3图片边框.本文对大家进行网站开发设计工作或者学习都有一定帮助,下面让我们进入正文. 使用CSS3 border-image 属性,你可以在元素 ...

  2. 一篇文章带你解决 SpringBoot 中 favicon 失效,不显示问题

    文章目录 一.常规思路 二.其他思路 一.常规思路 正常显示我们已经知道:一篇文章带你搞定 SpringBoot 自定义欢迎页和网页图标 favicon 如果正常设置不好使常规的思路是: (1)旧版的 ...

  3. 一篇文章带你了解Python中的游戏开发模块pyglet

    前言 为什么我不选择pygame,原因很简单,因为pyglet 更简单,比较轻量级,就好比django和flask的区别. 相信你在读了这篇文章之后也会毅然决然地选择pyglet. 这篇文章主要围绕p ...

  4. 一篇文章带你了解JavaScript中的函数表达式,递归,闭包,变量,this对象,模块作用域

    作者 | Jeskson 来源 | 达达前端小酒馆 定义函数的方式: 第一种为 函数声明: 第二种为 函数表达式. 语法: function functionName(arg0, arg1, arg2 ...

  5. 蚂蚁技术专家:一篇文章带你学习分布式事务

    小蚂蚁说: 分布式事务是企业集成中的一个技术难点,也是每一个分布式系统架构中都会涉及到的一个东西,特别是在这几年越来越火的微服务架构中,几乎可以说是无法避免,本文就围绕分布式事务各方面与大家进行介绍. ...

  6. 一篇文章带你解决 MongoDB 连接 localhost 和 127.0.0.1 可以连接,但是改成具体的IP地址就无法连接

    文章目录 一.出现的问题 二.解决方案 一.出现的问题 package mongodb;import com.mongodb.MongoClient; import com.mongodb.clien ...

  7. 一篇文章带你学会 Spring 中的 JdbcTemplate 增删改查操作

    文章目录 一.JdbcTemplate 概述 二.配置数据源 三.bean.xml配置文件 四.JdbcTemplate简单示例 五.批量操作多条记录 一.JdbcTemplate 概述 它是 spr ...

  8. 【一篇文章带你掌握HTML中ul、ol和dl列表的使用 - 超详细】

    前提 在项目开发过程中,列表是非常常见的,因此列表标签也是我们使用相对频繁的标签,但是当我们遇到列表的时候有没有停顿思考一下,我在这里应该使用html中的哪个列表标签才合理呢?    其实结合css样 ...

  9. 一篇文章带你了解JavaScript中的面向 “对象”

    作者 | Jeskson 来源 | 达达前端小酒馆 安装webpack,打包工具,安装webpack-dev-server,安装babel解析es6语法,初始化npm环境. npm install w ...

  10. 乐鑫esp8266学习rtos3.0笔记第3篇: 一篇文章带你搞掂存储技术 NVS 的认识和使用,如何利用NVS保存整型、字符串、数组以及结构体。(附带demo)

    本系列博客学习由非官方人员 半颗心脏 潜心所力所写,不做开发板.仅仅做个人技术交流分享,不做任何商业用途.如有不对之处,请留言,本人及时更改. 1. Esp8266之 搭建开发环境,开始一个" ...

最新文章

  1. mysql select 所有表_怎样用SQL语句查询一个数据库中的所有表
  2. numpy.newaxis详解
  3. 读取带空格字符串小结
  4. Visual C++中MFC消息的分类
  5. windows下虚拟机配置spark集群最强攻略!
  6. matlab运行为什么要选中代码,性能 – 为什么(在MATLAB中)这个代码更快?
  7. Delphi GDI对象之绘制文本
  8. postgresql 编写函数实现 获取中文姓名全拼
  9. C语言算法7744问题
  10. php wordpress 代码模板,wordpress模板代码详解
  11. 百钱百鸡:公鸡5元一只,母鸡3元一只,小鸡1元3只,100元要买100只鸡,共有几种情况
  12. 人工智能专家:AI并不像你想象的那么先进
  13. java盖金字塔的游戏,最强大脑积木金字塔
  14. java实现根号n路归并排序
  15. 转:明茨伯格:管理者的“选“、“育“、“评”
  16. break在c语言中的应用,c语言中break的用法
  17. 《C语言程序设计》文件
  18. VMware Workstation 不可恢复错误:(vmui)
  19. 华为OD机试 - 箱子之字形摆放
  20. bzoj2818: Gcd 莫比乌斯繁衍

热门文章

  1. DeFi市值突破100亿美元,背后是ChainLink、Band、Nest预言机三巨头的疯狂拉升
  2. 大国工匠 HTML,CSS接下文
  3. 如何搭建自己的AI绘画平台
  4. 双十二好用电容笔怎么选?十大电容笔知名品牌
  5. 翡翠Chalchiguite硬玉chalchiguite英语
  6. 硅谷不再:创业者和投资人都在离开
  7. 2022年Java求职经历
  8. SQL Server深入详解
  9. 抖音艺术签名小程序源码/艺术签名设计小程序源码/字节跳动小程序开发
  10. 【软工】第1次阅读作业