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

相关推荐
怎么就重名了15 分钟前
Kivy的属性系统
java·前端·数据库
编程饭碗34 分钟前
【Spring全局异常处理 早抛晚捕】
java·数据库·spring
hxjhnct44 分钟前
JavaScript Promise 的常用API
开发语言·前端·javascript
web小白成长日记1 小时前
前端让我明显感受到了信息闭塞的恐怖......
前端·javascript·css·react.js·前端框架·html
langsiming1 小时前
Redis底层实现
数据库·redis·缓存
Hello World呀1 小时前
Redis是AP的还是CP?
数据库·redis·缓存
自信阿杜2 小时前
跨标签页数据同步完全指南:如何选择最优通信方案
前端·javascript
指尖跳动的光2 小时前
Vue的nextTick()方法
前端·javascript·vue.js
皇族崛起3 小时前
【视觉多模态】- 3D建模尝试 I (广场3D建模,失败)
数据库·人工智能·3d·性能优化
JavaLearnerZGQ3 小时前
redis笔记大全
数据库·redis·笔记