zoukankan      html  css  js  c++  java
  • Elastic Stack:es JavaApi搜索入门

    一.入门API

    @SpringBootTest(classes = SearchApplication.class)
    @RunWith(SpringRunner.class)
    public class TestSearch {
        @Qualifier("restHighLevelClient")
        @Autowired
        RestHighLevelClient client;
    
        @Test
        public void testSearchAll() throws IOException {
            //构建搜索请求
            SearchRequest request = new SearchRequest("book");
            //构建搜索请求体
            SearchSourceBuilder builder = new SearchSourceBuilder();
            builder.query(QueryBuilders.matchAllQuery());
            //第一个参数:包含哪些字段  第二个参数:排除哪些字段
            builder.fetchSource(new String[]{},new String[]{"pic","timestamp"});
            request.source(builder);
            //执行搜索请求
            SearchResponse response = client.search(request, RequestOptions.DEFAULT);
            //获取结果
            SearchHits hits = response.getHits();
            SearchHit[] hits1 = hits.getHits();
            Arrays.asList(hits1).forEach(hit->{
                System.out.println(hit.getId());
                System.out.println(hit.getScore());
                Map<String, Object> map = hit.getSourceAsMap();
                map.forEach((x,y)-> System.out.println(x+":"+y));
                System.out.println("==========");
            });
        }
    }
    

     二.常用方法

    分页:

    builder.from(0);
    builder.size(2);
    

     ids查询:

    builder.query(QueryBuilders.idsQuery().addIds("1","3","5"));

    match搜索:

    builder.query(QueryBuilders.matchQuery("name","java编程"));

    multi_match搜索:

    第一个参数:查询的关键字

    后面的参数:查询的字段

    builder.query(QueryBuilders.multiMatchQuery("java","name","description"));
    

    三.bool query查询  

        @Test
        public void testSearchBool() throws IOException {
            //构建搜索请求
            SearchRequest request = new SearchRequest("book");
            //构建搜索请求体
            SearchSourceBuilder builder = new SearchSourceBuilder();
            //构建bool
            BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
            boolQueryBuilder.must(QueryBuilders.matchQuery("description","java"));
            boolQueryBuilder.should(QueryBuilders.matchQuery("name","开发"));
    
            builder.query(boolQueryBuilder);
            //第一个参数:包含哪些字段  第二个参数:排除哪些字段
            builder.fetchSource(new String[]{},new String[]{"pic","timestamp"});
            request.source(builder);
            //执行搜索请求
            SearchResponse response = client.search(request, RequestOptions.DEFAULT);
            //获取结果
            SearchHits hits = response.getHits();
            SearchHit[] hits1 = hits.getHits();
            Arrays.asList(hits1).forEach(hit->{
                System.out.println(hit.getId());
                System.out.println(hit.getScore());
                Map<String, Object> map = hit.getSourceAsMap();
                map.forEach((x,y)-> System.out.println(x+":"+y));
                System.out.println("==========");
            });
        }
    

     filter:

    boolQueryBuilder.filter(QueryBuilders.rangeQuery("price").gte("50").lte("90"));
    

     四.sort排序

     按照价格降序

        @Test
        public void testSearchSort() throws IOException {
            //构建搜索请求
            SearchRequest request = new SearchRequest("book");
            //构建搜索请求体
            SearchSourceBuilder builder = new SearchSourceBuilder();
            builder.query(QueryBuilders.matchAllQuery());
            //第一个参数:包含哪些字段  第二个参数:排除哪些字段
            builder.fetchSource(new String[]{},new String[]{"pic","timestamp"});
            //排序
            builder.sort("price", SortOrder.DESC);
            request.source(builder);
            //执行搜索请求
            SearchResponse response = client.search(request, RequestOptions.DEFAULT);
            //获取结果
            SearchHits hits = response.getHits();
            SearchHit[] hits1 = hits.getHits();
            Arrays.asList(hits1).forEach(hit->{
                System.out.println(hit.getId());
                System.out.println(hit.getScore());
                Map<String, Object> map = hit.getSourceAsMap();
                map.forEach((x,y)-> System.out.println(x+":"+y));
                System.out.println("==========");
            });
        }
    

      

  • 相关阅读:
    百度Tera数据库介绍——类似cassandra,levelDB
    Cassandra——类似levelDB的基于p2p架构的分布式NOSQL数据库
    Greenplum——升级的分布式PostgresSQL
    Neo4j图数据库简介和底层原理
    445. Add Two Numbers II ——while s1 or s2 or carry 题目再简单也要些测试用例
    22. Generate Parentheses——本质:树,DFS求解可能的path
    LevelDb简单介绍和原理——本质:类似nedb,插入数据文件不断增长(快照),再通过删除老数据做更新
    es根据磁盘使用情况来决定是否分配shard
    ES mlockall作用——preventing that memory from being paged to the swap area
    我相信我会反击!围绕艰苦的开局迫使程序员初尝体验
  • 原文地址:https://www.cnblogs.com/wwjj4811/p/13098982.html
Copyright © 2011-2022 走看看