Java中Elasticsearch使用类似MySQL的OR和AND查询

本文用实例来介绍如何使用Spring Data Elasticsearch的ElasticsearchRestTemplate来操作ES,在Java中Elasticsearch使用类似MySQL的OR和AND进行多条件查询。

官网

Elasticsearch Operations

bool query:

一种复合查询,把其余类型的查询包裹进来,支持以下三种逻辑关系。

java 复制代码
must: AND   
must_not:NOT
should:OR

ES查询实例如下:

javascript 复制代码
{
    "bool" : {
        "must" : { "term" : { "component" : "comp_1" } },  // must = And
        "should" : [                                       // should = Or
            { "term" : { "userId" : "A1A1" } },    
            { "term" : { "customerId" : "C1" } },
            { "term" : { "currentRole" : "ADMIN" }}
        ],
        "minimum_should_match" : 1
    }
}

在Java中代码示例:

java 复制代码
@Autowired
private ElasticsearchRestTemplate elasticsearchRestTemplate;

org.elasticsearch.index.query.QueryBuilder qb = QueryBuilders
    .boolQuery()
    .must(termQuery("component", currentComponent))
    .should(termQuery("userId", currentUserId))
    .should(termQuery("customerId", currentCustomerId))
    .should(termQuery("currentRole", ADMIN))
    // .must(QueryBuilders.boolQuery().should(QueryBuilders.termsQuery("num", "6","8")))
    .minimumNumberShouldMatch(1);

该must部分是ANDS;

该should部分都或多或少ORS;

除了你可以指定的最小数量should(用s到比赛minimum_should_match),这个最低默认为1,我认为(但你可以将其设置为0,这意味着文件不匹配的should条件也将被返回)。

如果要进行涉及嵌套ANDs和ORs的更复杂的查询,只需将其他布尔查询嵌套在内部must或should部分中。

另外,当您寻找准确的值(id等)时,也许可以使用术语查询代替匹配查询,从而节省了分析阶段的时间(如果对这些字段进行了分析,则不一定有意义)对于ID)。如果对它们进行了分析,则您仍然可以这样做,但前提是您必须确切地知道术语的存储方式(例如,标准分析器将它们存储为小写)。

匹配关键字示例:

复制代码
// es 查询满足条件1 或满足条件2 的结果合集
//主查询
matchQuery.must(
        QueryBuilders.boolQuery()
        .should(QueryBuilders.matchQuery("xm","好的"))//分词后匹配
            .should(QueryBuilders.matchParaseQuery("addr","钱江路"))//匹配完整词
            .should(QueryBuilders.termQuery("status",0))//完全匹配
            .should(QueryBuilders.termsQuery("keyword",string[]))//多关键字匹配
            );

    SearchResponse response = client.prepareSearch("indexName")
            .setFrom(0)
            .setSize(10)
            .setQuery(matchQuery)
            .get();

    SearchHits hits = response.getHits();
    int count = (int) hits.getTotalHits();

    for(SearchHit one:hits)
    {
        //遍历结果处理
    }

如果本篇文章对你有帮助的话,很高兴能够帮助上你。

当然,如果你觉得文章有什么让你觉得不合理、或者有更简单的实现方法又或者有理解不来的地方,希望你在看到之后能够在评论里指出来,我会在看到之后尽快的回复你。

相关推荐
会开花的二叉树1 分钟前
C++微服务 UserServer 设计与实现
开发语言·c++·微服务
像风一样自由20204 分钟前
Rust Tokio vs Go net/http:云原生与嵌入式生态选型指南
开发语言·golang·rust
DuHz6 分钟前
C程序中的数组与指针共生关系
linux·c语言·开发语言·嵌入式硬件·算法
我星期八休息10 分钟前
C++智能指针全面解析:原理、使用场景与最佳实践
java·大数据·开发语言·jvm·c++·人工智能·python
摇滚侠10 分钟前
Spring Boot 3零基础教程,WEB 开发 整合 Thymeleaf 笔记36
java·spring boot·笔记
大猫会长14 分钟前
docker安装php+apache
java·开发语言
野生技术架构师17 分钟前
JAVA 架构师面试题含答案:JVM+spring+ 分布式 + 并发编程
java·jvm·spring
道之极万物灭28 分钟前
Go小工具合集
开发语言·后端·golang
瑞士卷@29 分钟前
MyBatis入门到精通(Mybatis学习笔记)
java·数据库·后端·mybatis
梵得儿SHI39 分钟前
Java 反射机制深度剖析:性能与安全性的那些坑
java·开发语言·安全·反射·动态代理·性能·反射机制