我正在连接一个我无法控制的 API,并且希望提取符合特定条件的所有配方条目。在大多数情况下,这是一个简单的“值是否等于 N”,但是对于其中一个标准,我还必须检查另一个值是否大于 0。
这段代码工作得非常好:
should: [
{ match: { 'ItemResult.ItemAction.Type': 853 } },
{ match: { 'ItemResult.ItemAction.Type': 1013 } },
{ match: { 'ItemResult.ItemAction.Type': 1322 } },
{ match: { 'ItemResult.ItemAction.Type': 5845 } }
]
它为我提供了 'ItemResult.ItemAction.Type
为预期的 853、1013、1322 或 5845 的所有配方条目。问题来自于我的 should
数组的这个新的更复杂的条件:
range: {
'ItemResult.ItemAction.Type': { gte: 5100, lte: 5300 },
'ItemResult.ItemAction.Data0': { gt: 0 }
}, ...
每个单独的范围属性都工作正常,但当两者像上面一样组合时,我自然会收到以下错误:
"reason":"[range] query doesn\'t support multiple fields
有没有一种方法可以让我在同一个查询中考虑两个范围,而不影响其他 ItemResult.ItemAction.Type
值?
显然,我可以再次连接到 API 来执行更复杂的标准搜索,但我想知道是否可以在一次调用中完成所有操作。
最佳答案
{
"query": {
"bool": {
"must": [
{
"range": {
"ItemResult.ItemAction.Type": {
"gte": 5100,
"lte": 5300
}
}
},
{
"range": {
"ItemResult.ItemAction.Data0": {
"gt": 0
}
}
}
]
}
}
}
Elasticsearch 的 Range
不支持多个字段,但您可以使用此查询来获得多个 range
条件。
关于node.js - 单个 SHOULD 查询 block 中的多个条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56363798/