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里,每天在凌晨时去让定时任务去更新。

相关推荐
哆哆啦0011 分钟前
使用 Obsidian + GitHub Actions + GitHub Pages 搭建内容发布流
数据库·笔记·github·obsidian
duke86926721414 分钟前
PostgreSQL 中高效插入多对多关联数据的三种方案对比与最佳实践
jvm·数据库·python
迷枫71217 分钟前
达梦数据库备份还原:物理备份、逻辑备份
数据库
czlczl2002092522 分钟前
mysql表复制方案
数据库·mysql
m0_4636722031 分钟前
mysql数据库如何进行逻辑备份与物理备份对比_优缺点分析
jvm·数据库·python
2401_8676239835 分钟前
SQL如何进行分组后字符串拼接_使用GROUP_CONCAT或STRING_AGG
jvm·数据库·python
kexnjdcncnxjs38 分钟前
MySQL触发器无法触发的原因分析_MySQL触发器排查指南
jvm·数据库·python
六月雨滴1 小时前
存储性能监控与优化及最佳实践总结
数据库·oracle·dba
我先去打把游戏先1 小时前
【保姆级图文教程】:VMware虚拟机安装Ubuntu Server 22.04
linux·数据库·ubuntu
IpdataCloud1 小时前
企业级IP定位服务准确率怎么保证?从数据源到离线库的精度提升指南
运维·服务器·网络·数据库·tcp/ip