示例:
|studentname | maths | computers |
++++++++++++++++++++++++++++++++++
|s1 |78 |90 |
==================================
|s2 |56 |75 |
==================================
|s3 |45 |50 |
==================================
上表表示 Elasticsearch 中存在的数据。
假设用户输入60 and above
那么Elasticsearch应该只能显示s1,因为他是唯一一个两科都超过60分的学生.
如何使用 Java API 解决它?
注意:我能够通过以下方式找出个别主题:
QueryBuilder query = QueryBuilders.boolQuery()
.should(
QueryBuilders.rangeQuery(maths)
.from(50)
.to(100)
)
最佳答案
您可以在 bool 查询中有多个 .should()
子句。所以在你的情况下:
QueryBuilder query = QueryBuilders.boolQuery()
.should(
QueryBuilders.rangeQuery(maths)
.from(61)
.to(100)
)
.should(
QueryBuilders.rangeQuery(computers)
.from(61)
.to(100)
)
注意:
RangeQueryBuilder
(从QueryBuilders.rangeQuery()
返回)也有方法#gte()
。根据文档:“在没有 must 或 filter 子句的 boolean 查询中,一个或多个 should 子句必须与文档匹配。”因此,如果您没有
filter
或must
,您可能无法获得所需的行为。上面的答案假设您正在使用其他一些条款。 重点是您可以在 bool 查询中组合子句。对于 Java API,这仅意味着重复使用子句。您可能想使用 filter 而不是 should。这将导致更快的执行和缓存(https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-bool-query.html)
关于java - 我可以使用 Elastic Search Java API 按多个字段进行搜索吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43394976/