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”上有一个常规索引,它也包含在搜索索引中(定义为数字和动态映射关闭)
无论如何,是否可以在搜索管道内对任何字段(升序/降序)进行排序?
| 归档时间: |
|
| 查看次数: |
1247 次 |
| 最近记录: |