Elasticsearch中的查询API使用——term,match,query_string

 1. match:模糊匹配,需要指定字段名在指定字段上进行搜索,并且会对输入的查询字符串进行分词,依据分词的结果进行查询。Java API使用如下

        // 构建查询条件
        NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();
        // 添加基本的分词查询
        queryBuilder.withQuery(QueryBuilders.matchQuery("title", "小米"));

        // 执行搜索,获取结果
        Page<Item> items = this.itemRepository.search(queryBuilder.build());

 

2. term:不分词查询,该查询与match查询的区别就是不会对查询字符串进行分词处理,但同样需要指定查询字段。比如检索“华为手机”,就不会分为“华为”和“手机”两个条件进行检索,而是直接检索“华为手机”。使用API如下

        // 构建查询条件
        NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();
        // 添加基本的分词查询
        queryBuilder.withQuery(QueryBuilders.termQuery("category", "手机"));

3. query_string:和match类似,但是match需要指定字段名,query_string不需要指定字段名,是在所有字段中搜索,范围更广泛。

        // 构建查询条件
        NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();
        // 添加基本的分词查询
        queryBuilder.withQuery(QueryBuilders.queryStringQuery("手机"));

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 查询 ES 数据可以使用 ElasticsearchJava 客户端 API,该 API 封装了 ES 的各种查询操作,包括: 1. Term Query:根据关键词进行查询。 2. Match Query:根据匹配进行查询。 3. Range Query:根据范围进行查询。 4. Wildcard Query:根据通配符进行查询。 5. Fuzzy Query:根据模糊匹配进行查询。 6. Bool Query使用布尔运算符进行组合查询。 7. Filter Query使用过滤器进行查询。 8. Aggregation:使用聚合操作进行查询分析。 下面是一个示例代码,演示了如何使用 Java 客户端 API 进行 Term Query 查询: ``` // 创建 ES 客户端 RestHighLevelClient client = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); // 构建 Term Query 查询 QueryBuilder queryBuilder = QueryBuilders.termQuery("name", "John"); // 构建 SearchRequest SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder sourceBuilder = new SearchSourceBuilder(); sourceBuilder.query(queryBuilder); searchRequest.source(sourceBuilder); // 执行查询 SearchResponse response = client.search(searchRequest, RequestOptions.DEFAULT); // 处理查询结果 SearchHits hits = response.getHits(); for (SearchHit hit : hits) { Map<String, Object> sourceAsMap = hit.getSourceAsMap(); System.out.println(sourceAsMap); } // 关闭 ES 客户端 client.close(); ``` 以上代码,我们使用Term Query 进行查询查询条件为 name 字段等于 John。构建查询条件后,我们使用 SearchRequest 构建查询请求,指定查询的索引、查询条件等信息。然后使用 ES 客户端执行查询,并处理查询结果。最后记得关闭 ES 客户端。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值