ElasticSearch漫游 (10.RestClient 查询文档)

match_all

   @Test
    void testMatchAll() throws IOException {
       SearchRequest request = new SearchRequest("hotel");
       request.source().query(QueryBuilders.matchAllQuery()).size(10);
       SearchResponse response = client.search(request,RequestOptions.DEFAULT);

       SearchHits hits = response.getHits();

       long value = hits.getTotalHits().value;

       System.out.println("the sum is "+value);

       SearchHit[] searchHits = hits.getHits();

       for (SearchHit searchHit:searchHits){
           String json = searchHit.getSourceAsString();
           HotelDoc hotelDoc = JSON.parseObject(json,HotelDoc.class);
           System.out.println("the value is"+hotelDoc);
       }
   }

match

    @Test
    void testMatch() throws IOException {
        SearchRequest request = new SearchRequest("hotel");
        request.source().query(QueryBuilders.matchQuery("brand","如家"));
        SearchResponse response = client.search(request,RequestOptions.DEFAULT);

        extracted(response);
    }

term/range

 request.source().query(QueryBuilders.termQuery("brand","如家"));

 request.source().query(QueryBuilders.rangeQuery("price").gte(100).lte(200));

排序和分页

GET /hotel/_search
{
 "query": {
    "match_all": {}
 },
  "from": 0, 
  "size": 10,
 "sort": [
   {
     "price": "asc"
   }
 ]
}

以这段dsl查询为例:

    @Test
    void testPageAndSort() throws IOException {
        int page = 1, size =5;
        SearchRequest request = new SearchRequest("hotel");
        request.source().query(QueryBuilders.matchAllQuery());
        request.source().sort("price", SortOrder.ASC);
        request.source().from((page-1)*size).size(10);
        SearchResponse response = client.search(request,RequestOptions.DEFAULT);
        extracted(response);
    }

注意sort 和分页 与 query是平级的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值