码迷,mamicode.com
首页 > 其他好文 > 详细

elasticsearch高级组合查询ava

时间:2017-10-17 00:13:08      阅读:243      评论:0      收藏:0      [点我收藏+]

标签:print   string   tran   操作   out   pre   分页   索引   try   

/**
     * 高级检索(组合条件检索)must相当于sql and操作
     * @param modelType 0为模糊查询,1为精确查询
     * @param index 索引
     * @param map key为查询字段和value为查询内容
     * @param Page 分页页码
     * @param Pagesize 每页显示条数
     * @return SearchHits  
     */
    public static SearchHits AdvancedQuery1(Integer modelType,String index,Map<String,String> map,int Page,int Pagesize){
        SearchRequestBuilder sr =transportClient.prepareSearch(index);
        BoolQueryBuilder queryBuilder=QueryBuilders.boolQuery();
        System.out.println(index);
        if(modelType==0){
            for(Map.Entry<String, String> entry : map.entrySet()){

              //wildcardQuery 模糊查询
                queryBuilder.must(QueryBuilders.wildcardQuery(entry.getKey(), entry.getValue()+"*"));
            }
        }
        else if(modelType==1){
            for(Map.Entry<String, String> entry : map.entrySet()){

                 //termQuery 查询精确
                queryBuilder.must(QueryBuilders.termQuery(entry.getKey(),entry.getValue()));
            }
        }
        sr.setQuery(queryBuilder)
          .setFrom((Page-1)*Pagesize)
          .setSize(Pagesize);
        SearchResponse response=sr.get();
        SearchHits hits=response.getHits();
        return hits;
        
    }

elasticsearch高级组合查询ava

标签:print   string   tran   操作   out   pre   分页   索引   try   

原文地址:http://www.cnblogs.com/zengxiaoyi36/p/7679560.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!