首页 > 其他 > 详细

elasticsearch高级组合查询ava

时间:2017-10-17 00:11:20      阅读:291      评论:0      收藏:0      [点我收藏+]

/**
     * 高级检索(组合条件检索)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

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!