【问题标题】:how to build index in mongodb in this situation在这种情况下如何在 mongodb 中建立索引
【发布时间】:2014-01-13 06:52:03
【问题描述】:

我有一个 mongodb 数据库,它有以下字段:

{"word":"ipad", "date":20140113, "docid": 324, "score": 98}

这是一个文档日志(大约 1.2 亿)的反向索引。

我的系统中有两种查询: 其中之一是:

db.index.find({"word":"ipad", "date":20140113}).sort({"score":-1})

此查询获取日期为 20140113 的单词“ipad”,并按分数对所有文档进行排序。

另一个查询是:

db.index.find({"word":"ipad", "date":20140113, "docid":324})

要加快这两种查询,我应该建立什么索引?

我应该像这样建立两个索引吗?:

db.index.ensureIndex({"word":1, "date":1, "docid":1}, {"unique":true})

db.index.ensureIndex({"word":1, "date":1, "score":1}

但是我觉得建两个索引要用两个很大的硬盘空间。

那么你有什么好主意吗?

【问题讨论】:

    标签: mongodb indexing


    【解决方案1】:

    您正在按分数降序排序 (.sort({"score":-1})),这意味着您的索引也应该在分数字段上降序,以便它可以支持排序:

    db.index.ensureIndex({"word":1, "date":1, "score":-1});
    

    另一个索引看起来很好,可以加快查询速度,但您可能仍想通过在 mongo shell 中运行查询来确认这一点,然后是 .explain()

    索引始终是空间和写入性能与读取性能的权衡。当你负担不起空间时,你不能拥有索引并且必须处理它。但通常写入性能是更大的问题,因为驱动器空间通常很便宜。

    但也许您可以保存您拥有的三个索引之一。 “等等,三个索引?”是的,请记住,每个集合必须在集合初始化时隐式创建的 _id 字段上具有唯一索引。

    但 _id 字段不必是自动生成的 ObjectId。它可以是你想要的任何东西。当您有另一个具有唯一性约束的索引并且您对 _id 字段没有用处时,您可以将该唯一性约束移动到 _id 字段以保存索引。您的文档将如下所示:

    { _id: { 
         "word":"ipad", 
         "date":20140113, 
         "docid": 324
      },
      "score": 98
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-05-25
      • 2021-01-28
      • 2017-06-06
      • 2021-01-02
      • 1970-01-01
      • 1970-01-01
      • 2014-08-29
      • 1970-01-01
      相关资源
      最近更新 更多