elasticsearch嵌套聚合并排重获取数据

正经学徒,佛系记录,不搞事情

首先创建索引mapping,添加测试数据(由于目的是为了测试聚合,因此设置成keyword不分词)

PUT transcripts
{ 
    "mappings":{
        "transcripts":{
            "properties": {
                "name":{
                    "type":"keyword"
                },
                "score":{
                    "type":"keyword"
                },
                "sex":{
                    "type":"keyword"
                }
            }
        }
    }
}

测试数据如下:

namesexscore
张三100
张三90
李四80
李四70

 

 

 

 

 

 

如果是单纯的想获取去重后对应数量:

获取所有名字所对应的数量:

POST transcripts/transcripts/_search
{
   "query": {
      "match_all": {}
   },
   "size": 0,//统计是不需要原数据的
   "aggs": {
      "nameAlias": {//别名
        "terms": {
           "field": "name", //distinct的字段   
           "size":10
        }
      }
   }
}

结果:名为张三和李四的各两人

获取所有名字下所有性别所对应的数量:

POST transcripts/transcripts/_search
{
   "query": {
      "match_all": {}
   },
   "size": 0,
   "aggs": {
      "nameAlias": {
        "terms": {
           "field": "name",    
           "size":10
        },
        "aggs": {
          "sexAlias": {
            "terms": {
               "field": "sex",    
               "size":10
            }
          }
        }
      }
   }
}

 结果:张三下有1个女性,1一个男性,李四下有2个男性

如果想获取每个记录的具体值(即想要获取具体的分数):

主要语法如下:

"aggs": {
    "alias": {//别名
        "top_hits": {
            "size": 1//返回第n条匹配的值
        }
    }
}

获取所有名字匹配的一条的数据:

POST transcripts/transcripts/_search
{
   "query": {
      "match_all": {}
   },
   "size": 0,
   "aggs": {
      "nameAlias": {
        "terms": {
           "field": "name",    
           "size":10
        },
        "aggs": {
           "alias1": {
              "top_hits": {
                  "size": 1
              }
           }
        }
      }
   }
}

结果:_source 下展示了所有的文档数据

获取所有名字下所有性别匹配的一条数据:

POST transcripts/transcripts/_search
{
   "query": {
      "match_all": {}
   },
   "size": 0,
   "aggs": {
      "nameAlias": {
        "terms": {
           "field": "name",    
           "size":10
        },
        "aggs": {
          "sexAlias": {
            "terms": {
               "field": "sex",    
               "size":10
            },
            "aggs": {
               "alias1": {
                  "top_hits": {
                      "size": 1
                  }
               }
            }
          }
        }
      }
   }
}

 结果:_source 下展示了所有的文档数据

"aggregations": {
      "nameAlias": {
         "doc_count_error_upper_bound": 0,
         "sum_other_doc_count": 0,
         "buckets": [
            {
               "key": "张三",
               "doc_count": 2,
               "sexAlias": {
                  "doc_count_error_upper_bound": 0,
                  "sum_other_doc_count": 0,
                  "buckets": [
                     {
                        "key": "女",
                        "doc_count": 1,
                        "alias1": {
                           "hits": {
                              "total": 1,
                              "max_score": 1,
                              "hits": [
                                 {
                                    "_index": "transcripts",
                                    "_type": "transcripts",
                                    "_id": "FU7koWgB2ZoT18WIeKTI",
                                    "_score": 1,
                                    "_source": {
                                       "name": "张三",
                                       "sex": "女",
                                       "score": "90"
                                    }
                                 }
                              ]
                           }
                        }
                     },
                     {
                        "key": "男",
                        "doc_count": 1,
                        "alias1": {
                           "hits": {
                              "total": 1,
                              "max_score": 1,
                              "hits": [
                                 {
                                    "_index": "transcripts",
                                    "_type": "transcripts",
                                    "_id": "FE7koWgB2ZoT18WISaTx",
                                    "_score": 1,
                                    "_source": {
                                       "name": "张三",
                                       "sex": "男",
                                       "score": "100"
                                    }
                                 }
                              ]
                           }
                        }
                     }
                  ]
               }
            },
            {
               "key": "李四",
               "doc_count": 2,
               "sexAlias": {
                  "doc_count_error_upper_bound": 0,
                  "sum_other_doc_count": 0,
                  "buckets": [
                     {
                        "key": "男",
                        "doc_count": 2,
                        "alias1": {
                           "hits": {
                              "total": 2,
                              "max_score": 1,
                              "hits": [
                                 {
                                    "_index": "transcripts",
                                    "_type": "transcripts",
                                    "_id": "F07koWgB2ZoT18WItaQZ",
                                    "_score": 1,
                                    "_source": {
                                       "name": "李四",
                                       "sex": "男",
                                       "score": "70"
                                    }
                                 }
                              ]
                           }
                        }
                     }
                  ]
               }
            }
         ]
      }
   }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要实现 Elasticsearch嵌套聚合查询,你可以使用 Elasticsearch 的 AggregationBuilders 类来创建嵌套聚合查询。具体实现步骤如下: 1. 创建一个嵌套聚合查询,用于组合多个子聚合查询。 2. 在嵌套聚合查询添加多个子聚合查询,分别对应不同的聚合方式。 3. 如果你需要对子聚合查询进行分组,可以在子聚合查询添加 terms 聚合查询。 4. 如果你需要对子聚合查询进行计数,可以在子聚合查询添加 count 聚合查询。 5. 执行查询并处理结果。 以下是一个示例 Java 代码,用于实现 Elasticsearch嵌套聚合查询: ``` SearchResponse response = client.prepareSearch("index_name") .addAggregation( AggregationBuilders.nested("nested_agg", "nested_field") .subAggregation(AggregationBuilders.terms("term_agg") .field("term_field")) .subAggregation(AggregationBuilders.count("count_agg") .field("count_field"))) .execute() .actionGet(); Nested nestedAgg = response.getAggregations().get("nested_agg"); Terms termAgg = nestedAgg.getAggregations().get("term_agg"); long totalCount = nestedAgg.getAggregations().get("count_agg").getDocCount(); ``` 其,"index_name" 是你要查询的索引名称,"nested_field" 是你要进行嵌套聚合查询的字段名称,"term_field" 和 "count_field" 分别是你要进行分组和计数的字段名称。你可以根据实际情况进行修改。执行完查询后,你可以从查询结果获取嵌套聚合对象,并进一步获取子聚合对象的结果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

My name is Red ^^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值