Elasticsearch-核心篇(7)-JavaApi集成查询

1,646 阅读3分钟

参考文档:www.elastic.co/guide/en/el…

一、Elasticsearch依赖

1.1 Maven依赖

  • elasticsearch-rest-high-level-client,高级REST客户端对象
<dependencies>
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.13</version>
  </dependency>
  <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.74</version>
  </dependency>
  <dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.18</version>
  </dependency>

  <!-- es服务依赖 -->
  <dependency>
    <groupId>org.elasticsearch</groupId>
    <artifactId>elasticsearch</artifactId>
    <version>7.8.0</version>
  </dependency>
  <!-- es客户端依赖 -->
  <dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>7.8.0</version>
  </dependency>
</dependencies>

1.2 公共方法

  • json美化工具类
import com.alibaba.fastjson.JSONObject;
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;

@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
public class EsUser {
    private String name;
    private Integer age;
    private String sex;

    public String toJsonString() {
        return JSONObject.toJSONString(this);
    }
}

二、Elasticsearch测试

2.1 服务连接

  • RestHighLevelClient:高级客户端
import java.io.IOException;
import java.util.Objects;
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.junit.After;
import org.junit.Before;

public class ElasticsearchTest {
    /**
     * 连接客户端
     */
    private RestHighLevelClient client;

    @Before
    public void init() {
        HttpHost serverHost = new HttpHost("127.0.0.1", 9200);
        client = new RestHighLevelClient(RestClient.builder(serverHost));
    }

    @After
    public void destroy() {
        if (Objects.nonNull(client)) {
            try {
                client.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

2.2 索引操作

import com.codecoord.elasticsearch.utils.PrintUtil;
import java.io.IOException;
import java.util.Objects;
import org.apache.http.HttpHost;
import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequest;
import org.elasticsearch.action.support.master.AcknowledgedResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.client.indices.CreateIndexRequest;
import org.elasticsearch.client.indices.CreateIndexResponse;
import org.elasticsearch.client.indices.GetIndexRequest;
import org.elasticsearch.client.indices.GetIndexResponse;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

public class ElasticsearchIndexTest {
    /**
     * 连接客户端
     */
    private RestHighLevelClient client;

    @Before
    public void init() {
        HttpHost serverHost = new HttpHost("127.0.0.1", 9200);
        client = new RestHighLevelClient(RestClient.builder(serverHost));
    }

    @After
    public void destroy() {
        if (Objects.nonNull(client)) {
            try {
                client.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /**
     * 创建索引:有则报错,无则新建
     */
    @Test
    public void testCreate() throws IOException {
        CreateIndexRequest createIndexRequest = new CreateIndexRequest("java");
        CreateIndexResponse response = client.indices().create(createIndexRequest, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(response);
    }

    /**
     * 查询索引信息
     */
    @Test
    public void testQuery() throws IOException {
        GetIndexRequest request = new GetIndexRequest("java");
        GetIndexResponse response = client.indices().get(request, RequestOptions.DEFAULT);
        // 获取别名
        PrintUtil.buttyPrint(response.getAliases(), "getAliases");
        // 获取默认设置
        PrintUtil.buttyPrint(response.getDefaultSettings(), "getDefaultSettings");
        // 获取索引信息
        PrintUtil.buttyPrint(response.getIndices(), "getIndices");
        // 获取映射信息
        PrintUtil.buttyPrint(response.getMappings(), "getMappings");
    }

    /**
     * 删除索引
     */
    @Test
    public void testDelete() throws IOException {
        DeleteIndexRequest request = new DeleteIndexRequest("java");
        AcknowledgedResponse response = client.indices().delete(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(response);
    }
}

2.3 文档操作

  • 以下文档操作为示例操作,关于高级查询只需要变化query即可
import com.codecoord.elasticsearch.domain.EsUser;
import com.codecoord.elasticsearch.utils.PrintUtil;
import java.io.IOException;
import java.util.Objects;
import org.apache.http.HttpHost;
import org.elasticsearch.action.bulk.BulkRequest;
import org.elasticsearch.action.bulk.BulkResponse;
import org.elasticsearch.action.delete.DeleteRequest;
import org.elasticsearch.action.delete.DeleteResponse;
import org.elasticsearch.action.get.GetRequest;
import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.update.UpdateRequest;
import org.elasticsearch.action.update.UpdateResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.index.query.MatchAllQueryBuilder;
import org.elasticsearch.index.query.MatchQueryBuilder;
import org.elasticsearch.index.query.QueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;
import org.elasticsearch.search.sort.SortOrder;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

public class ElasticsearchDocTest {
    /**
     * 连接客户端
     */
    private RestHighLevelClient client;

    @Before
    public void init() {
        HttpHost serverHost = new HttpHost("127.0.0.1", 9200);
        client = new RestHighLevelClient(RestClient.builder(serverHost));
    }

    @After
    public void destroy() {
        if (Objects.nonNull(client)) {
            try {
                client.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /**
     * 创建文档
     */
    @Test
    public void testCreate() throws IOException {
        IndexRequest request = new IndexRequest();
        // 指定索引
        request.index("java");
        // 指定id
        request.id("1001");
        // 存储数据
        EsUser user = new EsUser("zhangsan", 30, "男");
        // 指定source内容
        request.source(user.toJsonString(), XContentType.JSON);
        // 请求
        IndexResponse response = client.index(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(response);
    }

    /**
     * 修改文档
     */
    @Test
    public void testUpdate() throws IOException {
        UpdateRequest request = new UpdateRequest();
        // 指定索引
        request.index("java");
        // 指定id
        request.id("1001");

        // 更新内容
        EsUser user = new EsUser("ES", 18, "女");
        request.doc(user.toJsonString(), XContentType.JSON);

        // ES请求
        UpdateResponse response = client.update(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(response);
    }

    /**
     * 文档查询
     */
    @Test
    public void testQuery() throws IOException {
        GetRequest request = new GetRequest().index("java").id("1001");
        GetResponse response = client.get(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(response.getSource());
    }

    /**
     * 删除文档
     */
    @Test
    public void testDelete() throws IOException {
        DeleteRequest request = new DeleteRequest().index("java").id("1001");
        DeleteResponse response = client.delete(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(response);
    }

    /**
     * 批量操作,针对于增删改
     */
    @Test
    public void testBatch() throws IOException {
        BulkRequest bulkRequest = new BulkRequest();
        // 先删除
        bulkRequest.add(new DeleteRequest().index("java").id("1001"));
        // 再添加
        EsUser user = new EsUser("EsJava", 18, "男");
        bulkRequest.add(new IndexRequest().index("java").id("1002").source(user.toJsonString(), XContentType.JSON));

        BulkResponse responses = client.bulk(bulkRequest, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(responses);
    }

    /**
     * match查询
     */
    @Test
    public void testAdvanceMatchQuery() throws IOException {
        SearchRequest request = new SearchRequest("java");

        // 查询条件构造
        SearchSourceBuilder builder = new SearchSourceBuilder();

        // 匹配查询
        /// QueryBuilders提供命令中的查询匹配关系
        /// 查询所有
        /// QueryBuilder queryBuilder = QueryBuilders.matchAllQuery();
        /// 单个查询
        /// QueryBuilder queryBuilder = QueryBuilders.matchQuery("age", 18);
        /// 短语匹配查询
        QueryBuilder queryBuilder = QueryBuilders.matchPhraseQuery("name", "EsJava");
        builder.query(queryBuilder);

        request.source(builder);
        SearchResponse responses = client.search(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(responses.getHits());
    }

    /**
     * bool查询
     */
    @Test
    public void testAdvanceBoolQuery() throws IOException {
        SearchRequest request = new SearchRequest("java");

        // 查询条件构造
        SearchSourceBuilder builder = new SearchSourceBuilder();
        BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();

        // must
        queryBuilder.must(QueryBuilders.matchQuery("age", 18));
        // mustNot
        queryBuilder.mustNot(QueryBuilders.matchQuery("sex", "女"));
        // should
        queryBuilder.should(QueryBuilders.matchQuery("name", "zhangsan"));

        builder.query(queryBuilder);
        request.source(builder);
        SearchResponse responses = client.search(request, RequestOptions.DEFAULT);
        PrintUtil.buttyPrint(responses.getHits());
    }

    /**
     * 分页查询
     */
    @Test
    public void testAdvancePageQuery() throws IOException {
        SearchRequest request = new SearchRequest("java");

        // 查询条件构
        SearchSourceBuilder builder = new SearchSourceBuilder();
        MatchAllQueryBuilder queryBuilder = QueryBuilders.matchAllQuery();

        // query <==> select
        builder.query(queryBuilder);

        // 分页查询
        builder.from(0);
        builder.size(2);

        // 指定排序
        builder.sort("age", SortOrder.ASC);

        request.source(builder);
        SearchResponse responses = client.search(request, RequestOptions.DEFAULT);
        for (SearchHit searchHit : responses.getHits()) {
            System.out.println(searchHit.getSourceAsString());
        }
    }

    /**
     * 高亮查询
     */
    @Test
    public void testAdvanceHighLightQuery() throws IOException {
        SearchRequest request = new SearchRequest("java");

        // 查询条件构
        SearchSourceBuilder builder = new SearchSourceBuilder();
        // 注意高亮全部查询时无意义
        MatchQueryBuilder queryBuilder = QueryBuilders.matchQuery("name", "java");
        builder.query(queryBuilder);

        // 高亮搜搜,和查询同级
        HighlightBuilder highlightBuilder = new HighlightBuilder();
        highlightBuilder.preTags("<font color='red'>");
        highlightBuilder.postTags("</font>");
        highlightBuilder.field("name");

        builder.highlighter(highlightBuilder);
        request.source(builder);
        SearchResponse responses = client.search(request, RequestOptions.DEFAULT);
        for (SearchHit searchHit : responses.getHits()) {
            System.out.println(searchHit.getHighlightFields());
        }
    }
}