MongoDB的索引与索引字段的顺序

想提高数据库的查询效率需要建立索引,用索引查询。使用索引查询和不使用索引查询提升的效率和数据库表的记录条数和调用此时有关系。若记录足够大,用索引查询和不用索引查询相差一千倍以上很正常。

MongoDB默认为主键字段_id创建唯一索引,这个索引可以确保每个文档在集合中的唯一性。在MongoDB中,_id字段是自动生成的,除非在插入文档时显式指定一个值。这个_id索引是升序索引,用于快速查找和检索文档。

索引是多个字段的,查询时要注意索引的字段顺序。调用时的字段相同更能利用索引。虽然在原则上索引的顺序对查询效率影响不大。但是在循环查询,多线程操作数据库时还是有可能影响效率的。

我们见到一个循环查询超过了571毫秒,后来经过分析代码:

复制代码
for (let x of list) {
        let score = await AModel.findOne({
            type: 'total',
            area_id: x.id
        }, '-_id').lean().exec();
        x.score = score && score.score || 0;
    }

数据库索引:

复制代码
AValueSchema.index({area_id: 1, type: 1});

通过修改查询的字段顺序,能减少这种因为并发操作影响数据库的查询效率。当然若你在一张表上创建过多的索引,同样影响数据库的操作效率。解决这种循环查询数据库和并发操作数据引起超过1秒的处理的解决方式是尽量不用循环查询数据库,把这种非及时更新的大批量查询结果放在redis里,每天在凌晨时去让定时任务去更新。

相关推荐
知识分享小能手3 分钟前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019 触发器 — 语法知识点及使用方法详解(17)
数据库·学习·sqlserver
tod1136 分钟前
Redis Sentinel 高可用架构:从原理到 Docker 部署全解析
数据库·redis·docker·架构·sentinel
Xin_z_8 分钟前
Vue3 + Element Plus el-tree 节点点击选中问题修复总结
前端·javascript·vue.js
014-code8 分钟前
Redis 是如何实现与数据库的一致性呢?
数据库·redis·缓存
linux_cfan13 分钟前
从“线性观看”到“语义检索”:企业级视频知识库播放器选型指南 (2026版)
javascript·学习·音视频·html5
清水白石00815 分钟前
缓存的艺术:Python 高性能编程中的策略选择与全景实战
开发语言·数据库·python
AI Echoes21 分钟前
对接自定义向量数据库的配置与使用
数据库·人工智能·python·langchain·prompt·agent
专注VB编程开发20年27 分钟前
多线程,CS多台电脑redis扣款不出错方案
数据库·redis·缓存
zh_xuan29 分钟前
React Native 原生和RN互相调用以及事件监听
android·javascript·react native
菩提小狗35 分钟前
小迪安全2023-2024|第14天:信息打点-JS架构&框架识别&泄漏提取&API接口枚举&FUZZ爬虫&笔记|web安全|渗透测试|
javascript·安全·架构