首页 > 解决方案 > Mongodb:使用排序键作为复合索引的一部分还是在它自己的索引中?

问题描述

假设您有以下集合:

{name: 'john', occupation: 'engineer', country: 'UK', age: 20},
{name: 'allan', occupation: 'teacher', country: 'US', age: 25},
...

你需要找到一些人(例如所有名叫凯文的毒贩)并按照他们的年龄对他们进行排序:

collection.find({name: 'kevin', occupation: 'drug-dealer'}).sort({age: -1})

稍后您可能会执行不同的查询,在其中找到所有毒贩(无论他们的名字)并按年龄对他们进行排序:

collection.find({occupation: 'drug-dealer'}).sort({age: -1})

有一个单独的“年龄”索引或将其作为几个复合索引的一部分会更好吗?

部分复合指数:

{occupation: 1, age: 1}
{name: 1, occupation: 1, age:1}

单独索引:

{occupation: 1}
{name: 1, occupation: 1}
{age: 1}

什么会产生最好的性能?各自的优缺点是什么?

标签: mongodbindexingindices

解决方案


复合索引就可以了。由于您正在查询中运行排序,因此请确保以正确的顺序构建复合索引,以便您的查询不仅可以利用索引来过滤文档,还可以对它们进行排序。否则 mongodb 将执行效率不高且限制为 32 MB 的内存中排序


推荐阅读