Mongodb: 使用排序键作为复合索引的一部分还是在它自己的索引中?

Mongodb: Use sort key as part of compound index or in its own index?

假设您有以下 collection:

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

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

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

稍后你可能会做一个不同的查询,你会找到所有 drug-dealers(不管他们的名字)并按他们的年龄排序:

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

在 'age' 上有一个单独的索引还是让它成为几个复合索引的一部分更好?

部分复合指数:

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

单独索引:

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

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

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