node.js - 单个 SHOULD 查询 block 中的多个条件

标签 node.js elasticsearch

我正在连接一个我无法控制的 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/

相关文章:

javascript - 我应该通过 Node 应用程序中的 Restful api 进行所有数据库调用吗?

docker - 在 S3 中备份在 Docker 上运行的 ElasticSearch 的最佳方法

elasticsearch - 大型查询时Elasticsearch结果不一致

java - @GeoPointField Elasticsearch 的错误映射

node.js - 当我尝试在环回 (strongloop) web 应用程序中安装依赖项时出现 Npm 错误

node.js - Nodejs + mikeal/Request模块,如何关闭请求或增加MaxSockets

javascript - 路由在 Angular 和 Nodejs 应用程序中不起作用

node.js - React 应用程序使用什么服务器端代码

Elasticsearch:edgeNGram 标记过滤器是否适用于非英语标记?

elasticsearch - 我可以对多个k8集群使用单个elasticsearch/kibana吗?