node.js mongoose index(索引)

目录

简介

索引类型

单索引

复合索引

文本索引


简介

在 Mongoose 中,索引(Index)是一种用于提高查询性能的数据结构,它可以加速对数据库中文档的检索操作

索引类型

单索引、复合索引、文本索引、多键索引、哈希索引、地理位置空间索引、通配符索引

单索引

在了解索引之前先看一下mongoDb库,库中集合tours有400条数据,有slug、ratingAverage、price、summary等字段,接下来就是对以上四个字段做索引

我们查询slug为the-forest-hiker的文档,在 MongoDB 中,explain方法用于获取有关查询执行计划的详细信息,为Query的原型方法,调用:const queryInfo = await query.explain(),查看执行结果

其中totalDocsExamined为400,表示扫描了400个文档,nReturend为1表示匹配并返回文档的数量为1。

查询一条数据就需要把整个集合全部扫描效率过于低,当文档个数少的情况下可以忽略查询速度,如果文档个数数以万计,那么就要优化查询速度,所以需要索引。

为slug添加索引,schema.index({ slug: 1 }) (1表示升序,-1表示降序),再查询

javascript 复制代码
tourSchema.index({ slug: 1 });

也可在定义schema的时候设置文档字段的schemaType的index为true

此时totalDocsExamined为1,表示只扫描了1个文档,极大的提高了查询速度。

当执行query后,slug_1的Usage为1,表示索引命中了一次。

复合索引

javascript 复制代码
tourSchema.index({ price: 1, ratingsAverage: -1 });

同时为两个字段添加索引,表示先对price进行升序,然后在同price的情况下进行ratingsAverage降序。

查询price大于等于1000并且ratingsAverage大于等于4的文档,查询详细信息totalDocsExamined为5,nReturend为5,如果不设置复合索引,对两个字段进行复合查询的时候,会对全文档进行查询匹配。

文本索引

javascript 复制代码
tourSchema.index({ summary: 'text' });
javascript 复制代码
 const doc = await tourModel.find({ $text: { $search: 'National' }});

查询信息

如果不创建索引,则扫描全文档。

多键索引是针对数组

相关推荐
范纹杉想快点毕业3 小时前
《嵌入式开发硬核指南:91问一次讲透底层到架构》
java·开发语言·数据库·单片机·嵌入式硬件·mongodb
长空任鸟飞_阿康5 小时前
AI 多模态全栈应用项目描述
前端·vue.js·人工智能·node.js·语音识别
百***78458 小时前
node.js+npm的环境配置以及添加镜像(保姆级教程)
arcgis·npm·node.js
百***07189 小时前
Node.js 与 Docker 深度整合:轻松部署与管理 Node.js 应用
docker·容器·node.js
菠萝+冰9 小时前
npm中-d -g 和默认安装的区别
前端·npm·node.js
夏日不想说话11 小时前
一文搞懂 AI 流式响应
前端·node.js·openai
百***670312 小时前
Node.js实现WebSocket教程
websocket·网络协议·node.js
q***518912 小时前
如何在Windows系统上安装和配置Node.js及Node版本管理器(nvm)
windows·node.js
天天进步201514 小时前
Webpack到Vite:构建工具迁移实战经验总结
前端·webpack·node.js
好奇的菜鸟14 小时前
解决 Node.js 18+ 构建错误:digital envelope routines::unsupported 完全指南
node.js