JAVA使用ElasticSearch查询in和notin的实现方式
ElasticSearch
西工网站制作公司哪家好,找创新互联!从网页设计、网站建设、微信开发、APP开发、响应式网站等网站项目制作,到程序开发,运营维护。创新互联自2013年起到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联。
Elasticsearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。
最近用到ES
查询,因用的是Java写的,需要实现一个需求:过滤一部分id,查询时不需要查出来。
既然需要不包含,那么首先需要实现包含的方式(精确完全匹配),这里我们要用到的是termQuery
首先看下ES Bool
联合查询的属性:
bool联合查询: must,should,must_not
联合查询就会使用到must
,should
,must_not
三种关键词。
这三个可以这么理解
- must: 文档必须完全匹配条件
- should: should下面会带一个以上的条件,至少满足一个条件,这个文档就符合should
- must_not: 文档必须不匹配条件
具体案例,我需要过滤掉不用的exerciseId
:
BoolQueryBuilder exersiceBoolQuery = QueryBuilders.boolQuery(); if (exersiceIds != null && exersiceIds.size() > 0) { for (String exerciseId: exersiceIds) { exersiceBoolQuery.mustNot(QueryBuilders.termQuery("id", exerciseId)); } }
最后在发送请求的时候,加上你的exersiceBoolQuery
即可
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对创新互联的支持。如果你想了解更多相关内容请查看下面相关链接
网站名称:JAVA使用ElasticSearch查询in和notin的实现方式
本文路径:http://pcwzsj.com/article/geggso.html