zoukankan      html  css  js  c++  java
  • ES代码

    范围查询


     /**
         * 范围查询range
         * @throws IOException
         */
        @Test
        public  void testRange() throws IOException {
            ///创建构造器
            RangeQueryBuilder rangeQueryBuilder = QueryBuilders.rangeQuery("price");
            //指定下限2000,上限3000
            rangeQueryBuilder.gte(2000);
            rangeQueryBuilder.lte(3000);
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(rangeQueryBuilder);
            //指定搜索构造器的排序方式
            searchSourceBuilder.sort("price", SortOrder.ASC);
            //指定搜索构造器的分页信息
            searchSourceBuilder.from(0);
            searchSourceBuilder.size(100);
            ///创建搜索请求对象searchRequest指定搜索的索引名称goods
            SearchRequest searchRequest = new SearchRequest("goods");
            //搜索请求对象指定搜索构造器searchSourceBuilder为我们要使用的搜索工具
            searchRequest.source(searchSourceBuilder);
            ///创建搜索返回对象拿到指定搜索请求的搜索结果
            SearchResponse searchResponse = client.search(searchRequest,RequestOptions.DEFAULT);
            ///创建搜索命中数对象从搜索返回对象中拿到命中数
            SearchHits searchHits = searchResponse.getHits();
            ///创建一个集合
            List<Goods> goodsList = new ArrayList<>();
            //以集合方式获取命中的数据
            for (SearchHit searchHit : searchHits) {
                //获取json字符串格式的数据
                String sourceAsString = searchHit.getSourceAsString();
                //字符串转为java对象
                Goods goods  = JSON.parseObject(sourceAsString,Goods.class);
                goodsList.add(goods);
            }
            ///打印一下
            for (Goods goods : goodsList) { System.out.println(goods); }
        }
    

    查询全部match_all:

    查询全部数据,一般不会用这个。

            //创建查询构造器queryBuilder来指定查询matchAllQuery
            QueryBuilder queryBuilder = QueryBuilders.matchAllQuery();
    
            //创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式为查询构造器queryBuilder指定查询matchAllQuery
            searchSourceBuilder.query(queryBuilder);
    

    词条查询/精确查询term:

    完全匹配,搜索“小米手机”那么结果必须是“小米手机”这四个字连着,如果搜索“小米iphoneXR”则什么结果都不会返回(除非数据库里有数据真的写的是“小米iphoeneXR”),一般用于选择品牌,高级选项等位置。

            //创建查询构造器queryBuilder来指定查询termQuery
            //QueryBuilder queryBuilder = QueryBuilders.termQuery("title","小米");
            BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
            boolQueryBuilder.filter(QueryBuilders.termQuery("title","华为"));
            //创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式为查询构造器queryBuilder指定查询termQuery
            //searchSourceBuilder.query(queryBuilder);
            searchSourceBuilder.query(boolQueryBuilder);
    
    

    分词查询match:

    先分词,比如搜索“小米手机”,通过ik分词器分为“小米”和“手机”,“小米”和“手机”有两种逻辑,一种是and,一种是or
    如果选择and逻辑:
    搜索结果为“xxxx小米xxxxxxxx手机xxxx”,结果较少。
    如果选择or逻辑:
    搜索结果为“xxxx小米xxxxxxxx手机xxxx”,“xxxxxx小米xxxx”,“xxxxx手机xxxx”,结果较多。

            //创建查询构造器其父类MatchQueryBuilder来指定查询*Query
            MatchQueryBuilder matchQueryBuilder = QueryBuilders.matchQuery("title","小米手机");
            //and逻辑,or逻辑在后面改为OR即可
            matchQueryBuilder.operator(Operator.AND);
    
            //创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式为查询构造器queryBuilder指定查询*Query
            //searchSourceBuilder.query(queryBuilder);
            searchSourceBuilder.query(matchQueryBuilder);
    

    模糊查询wildcard:

            ///创建模糊查询构造器wildcardQueryBuilder来指定查询*Query
            WildcardQueryBuilder wildcardQueryBuilder = QueryBuilders.wildcardQuery("title","小*");
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式为模糊查询构造器wildcardQueryBuilder
            searchSourceBuilder.query(wildcardQueryBuilder);
    

    正则查询Regexp:

            ///创建构造器
            RegexpQueryBuilder regexpQueryBuilder = QueryBuilders.regexpQuery("title", "\w+(.)*");
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(regexpQueryBuilder);
    

    前缀查询:

            ///创建构造器
            PrefixQueryBuilder prefixQueryBuilder = QueryBuilders.prefixQuery("brandName","小");
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(prefixQueryBuilder);
    

    多字段查询queryString:

    ///创建构造器
            QueryStringQueryBuilder queryStringQueryBuilder = QueryBuilders.queryStringQuery("小米手机").field("title").field("categoryName").field("brandName").defaultOperator(AND);
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(queryStringQueryBuilder);
            //指定搜索构造器的排序方式
            searchSourceBuilder.sort("price", SortOrder.ASC);
    

    多条件拼接boolQuery:

    must筛选并计算分支:
    should:
    must_not:
    filter筛选并不计算分值,效率高,推荐使用:

            ///创建各个查询条件:品牌brandName
            QueryBuilder queryTermBuilder = QueryBuilders.termQuery("brandName","小米");
            ///创建各个查询条件:标题title
            QueryBuilder queryMatchQuery = QueryBuilders.matchQuery("title","手机");
            ///创建各个查询条件:价格范围priceRange
            RangeQueryBuilder priceRangeQueryBuilder = QueryBuilders.rangeQuery("price");
            ///创建布尔查询构造器
            BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
            boolQueryBuilder.must(queryTermBuilder);
            boolQueryBuilder.filter(queryMatchQuery);
            boolQueryBuilder.filter(priceRangeQueryBuilder);
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(boolQueryBuilder);
    

    聚合查询——桶聚合Agg:

        public  void testAgg() throws IOException {
            ///创建构造器
            MatchQueryBuilder matchQueryBuilder = QueryBuilders.matchQuery("title", "手机");
            ///创建聚合构造器
            AggregationBuilder aggregationBuilder = AggregationBuilders.terms("goods_brands").field("brandName").size(100);
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(matchQueryBuilder);
            //指定搜索构造器查询聚合
            searchSourceBuilder.aggregation(aggregationBuilder);
            //指定搜索构造器的分页信息
            searchSourceBuilder.from(0);
            searchSourceBuilder.size(100);
            ///创建搜索请求对象searchRequest指定搜索的索引名称goods
            SearchRequest searchRequest = new SearchRequest("goods");
            //搜索请求对象指定搜索构造器searchSourceBuilder为我们要使用的搜索工具
            searchRequest.source(searchSourceBuilder);
            ///创建搜索返回对象拿到指定搜索请求的搜索结果
            SearchResponse searchResponse = client.search(searchRequest,RequestOptions.DEFAULT);
            ///创建搜索命中数对象从搜索返回对象中拿到命中数
            SearchHits searchHits = searchResponse.getHits();
            ///创建一个集合
            List<Goods> goodsList = new ArrayList<>();
            //以集合方式获取命中的数据
            for (SearchHit searchHit : searchHits) {
                //获取json字符串格式的数据
                String sourceAsString = searchHit.getSourceAsString();
                //字符串转为java对象
                Goods goods  = JSON.parseObject(sourceAsString,Goods.class);
                goodsList.add(goods);
            }
            ///打印一下
            for (Goods goods : goodsList) { System.out.println(goods); }
    
            //获取聚合结果
            Aggregations aggregations = searchResponse.getAggregations();
            Map<String, Aggregation> aggregationMap = aggregations.asMap();
            Terms goods_brands = (Terms)aggregationMap.get("goods_brands");
            List<? extends Term.Bucket>  buckets = goods_brands.getBuckets();
            List brands = new ArrayList();
            for (Term.Bucket bucket : buckets) {
                Object key = bucket.getKey();
                brands.add(key);
            }
            for (Term.Bucket bucket : buckets) {
                System.out.println(brands);
            }
        }
    

    高亮聚合highlight:

        public  void testHighlight() throws IOException {
            ///创建构造器
            MatchQueryBuilder matchQueryBuilder = QueryBuilders.matchQuery("title","手机");
            ///创建高亮构造器和设置三要素
            HighlightBuilder highlightBuilder = new HighlightBuilder();
            highlightBuilder.field("title");
            highlightBuilder.preTags("<font color='red'>");
            highlightBuilder.postTags("</font>");
            ///创建搜索构造器searchSourceBuilder
            SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
            //指定搜索构造器的查询方式
            searchSourceBuilder.query(matchQueryBuilder);
            //指定搜索构造器的高亮模式
            searchSourceBuilder.highlighter(highlightBuilder);
            //指定搜索构造器的分页信息
            searchSourceBuilder.from(0);
            searchSourceBuilder.size(100);
            ///创建搜索请求对象searchRequest指定搜索的索引名称goods
            SearchRequest searchRequest = new SearchRequest("goods");
            //搜索请求对象指定搜索构造器searchSourceBuilder为我们要使用的搜索工具
            searchRequest.source(searchSourceBuilder);
            ///创建搜索返回对象拿到指定搜索请求的搜索结果
            SearchResponse searchResponse = client.search(searchRequest,RequestOptions.DEFAULT);
            ///创建搜索命中数对象从搜索返回对象中拿到命中数
            SearchHits searchHits = searchResponse.getHits();
            ///创建一个集合
            List<Goods> goodsList = new ArrayList<>();
            //以集合方式获取命中的数据
            for (SearchHit searchHit : searchHits) {
                //获取json字符串格式的数据
                String sourceAsString = searchHit.getSourceAsString();
                //字符串转为java对象
                Goods goods  = JSON.parseObject(sourceAsString,Goods.class);
                //获取高亮结果,替换goods中的title
                Map<String, HighlightField> highlightFieldMap = searchHit.getHighlightFields();
                HighlightField highlightField = highlightFieldMap.get("title");
                Text[] fragments = highlightField.fragments();
                goods.setTitle(fragments[0].toString());
                goodsList.add(goods);
            }
            ///打印一下
            for (Goods goods : goodsList) { System.out.println(goods); }
        }
    
  • 相关阅读:
    ubuntu 安装 库文件
    java接口定义的静态方法和默认如何在类实现的时候使用
    通过java的i/o机制进行图片流的存储以及对网络图片的存储
    java的两种冒泡算法
    Java的Integer和int有什么区别
    使用jq的ajax实现对xml文件的读取
    typescript中的工具 tsd
    使用reactjs遇到Warning: setState(...): Can only update a mounted or mounting component.
    在create-react-app的脚手架里面使用scss
    使用fetch-jsonp进行跨域以及参数的传递
  • 原文地址:https://www.cnblogs.com/maomaodesu/p/12631808.html
Copyright © 2011-2022 走看看