对 MongoDb Atlas 搜索管道中的任何字段进行排序

Jim*_*son 5 mongodb mongodb-query mongodb-atlas

我有一个测试数据集(500k 行)

    {
        "_id": ObjectId("61309575c9346aab086f91fb"),
        "listId": ObjectId("61309575c9346aab086f91fa"),
        "createdDate": ISODate("2021-09-02T09:12:21.594Z"),
        "es0": "Firstname 0 Moscow",
        "es1": "firstname0@gmail.com",
        "es2": "0701230000",
        "es3": "Equatorial Guinea",
        "es4": "Iceland",
        "es5": "Los Angeles International Airport",
        "ed0": ISODate("1975-10-17T00:00:00Z"),
        "ed1": ISODate("2020-01-01T00:00:00Z"),
        "ei0": 46,
        "ei1": 1345
    }
Run Code Online (Sandbox Code Playgroud)

我有一个这样的测试查询

    db.collection.aggregate([{
        $search: {
          "index": "test_index1",
          "compound": { 
            "filter": [{
                "equals": {
                  "path": "listId",
                  "value": ObjectId("613098df46239505942b8b13")
              }
            }],
            "must": [{
                "text": {
                    "query": 'Los Angeles',
                    "path": {
                      'wildcard': '*'
                    }
                  }
            }]
          }
        }
      }, 
      {
        $limit: 10
      }]);
Run Code Online (Sandbox Code Playgroud)

这是超级快的。

但如果我添加排序阶段(在 $limit 之前)

    {
        $sort: {
            ei0: -1
        }
    }
Run Code Online (Sandbox Code Playgroud)

它变得非常慢

我确实在“ei0”上有一个常规索引,它也包含在搜索索引中(定义为数字和动态映射关闭)

无论如何,是否可以在搜索管道内对任何字段(升序/降序)进行排序?

Okk*_*ano 1

文档中,他们说:

在 $search 阶段之后使用 $sort 聚合管道阶段会大大减慢查询结果的速度。

您应该在图集搜索中使用运算符对结果进行排序。

您还可以自定义查询分数以对其进行排序。