热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ElastaticSearchtop_hits,es获取聚合的相关文档结果

使用场景使用es聚合时,有时还需要获取query(或filter)的相关文档结果(数据)。比如统计各个地区编码的营业额,得到了聚合的统


使用场景

使用es聚合时,有时还需要获取query(或filter) 的相关文档结果(数据)。

比如统计各个地区编码的营业额,得到了聚合的统计结果,还想知道query结果中对应的地区名称,并根据营业额进行排序,

这时可以使用 top_hits。

top_hits属性

top_hits有以下的属性:

from - 从第几个结果开始获取。size - 每个桶返回的query结果的数量。默认情况下,返回前三个匹配的结果。sort - 根据字段进行排序。默认情况下,按主查询的分数排序。

top_hits的DSL

格式如下:

{"size" : 0,"query" : { },"aggregations" : {"自己命名的聚合名称" : {"terms" : {"field" : "聚合字段","size" : 10000,"order" : {"_term" : "asc"}},"aggregations" : {"hits" : {"top_hits" : {"sort": [{"排序字段": {"order": "desc"}}],"from" : 0,"size" : 5}},"自己命名的聚合统计的名称" : {"sum" : {"field" : "聚合统计字段"}}}}}
}

示例如下:

{"size" : 0,"query" : { },"aggregations" : {"agg_area" : {"terms" : {"field" : "area","size" : 10000,"order" : {"_term" : "asc"}},"aggregations" : {"hits" : {"top_hits" : {"sort": [{"amount": {"order": "desc"}}],"from" : 0,"size" : 5}},"area_sum" : {"sum" : {"field" : "amount"}}}}}
}

top_hits的java代码

java代码格式:

public static String getTopHitsDSL() {SearchSourceBuilder searchSourceBuilder = SearchSourceBuilder.searchSource();AggregationBuilder areaCodeAgg = AggregationBuilders.terms(自己命名的聚合名称).field(聚合字段).order(Terms.Order.aggregation("_term", true)).size(10000).subAggregation(AggregationBuilders.topHits("hits").sort(排序字段).size(5)).subAggregation(AggregationBuilders.sum(自己命名的聚合统计的名称).field(聚合字段));return searchSourceBuilder.query().aggregation(areaCodeAgg).size(0).toString();}

如下所示:

public static String getTopHitsDSL() {SearchSourceBuilder searchSourceBuilder = SearchSourceBuilder.searchSource();AggregationBuilder areaCodeAgg = AggregationBuilders.terms("agg_area").field("area").order(Terms.Order.aggregation("_term", true)).size(10000).subAggregation(AggregationBuilders.topHits("hits").sort("amount").size(5)).subAggregation(AggregationBuilders.sum("area_sum").field("amount"));return searchSourceBuilder.query().aggregation(areaCodeAgg).size(0).toString();}

参考资料:

http://itindex.net/detail/60468-elasticsearch-top-hits


推荐阅读
  • 本文详细介绍了Elasticsearch中的分页查询机制,包括基本的分页查询流程、'from-size'浅分页与'scroll'深分页的区别及应用场景,以及两者在性能上的对比。 ... [详细]
  • flea,frame,db,使用,之 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 数据输入验证与控件绑定方法
    本文提供了多种数据输入验证函数及控件绑定方法的实现代码,包括电话号码、数字、传真、邮政编码、电子邮件和网址的验证,以及报表绑定和自动编号等功能。 ... [详细]
  • 1、编写一个Java程序在屏幕上输出“你好!”。programmenameHelloworld.javapublicclassHelloworld{publicst ... [详细]
  • MITM(中间人攻击)原理及防范初探(二)
    上一篇文章MITM(中间人攻击)原理及防范初探(一)给大家介绍了利用ettercap进行arp欺骗及劫持明文口令,后来我发现好友rootoorotor的文章介绍比我写的更透彻,所以基础利用大家可以参看 ... [详细]
  • td{border:1pxsolid#808080;}参考:和FMX相关的类(表)TFmxObjectIFreeNotification ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本文详细介绍了如何利用 Bootstrap Table 实现数据展示与操作,包括数据加载、表格配置及前后端交互等关键步骤。 ... [详细]
  • 在尝试通过自定义端口部署Spring Cloud Eureka时遇到了连接失败的问题。本文详细描述了问题的现象,并提供了有效的解决方案,以帮助遇到类似情况的开发者。 ... [详细]
  • 根据官方定义,RxJava是一种用于异步编程和可观察数据流的API。其核心特性在于流式处理能力和丰富的操作符支持。 ... [详细]
  • 本文详细介绍了如何在Android应用中实现重复报警功能。示例代码可在以下路径找到:https://developer.android.com/samples/RepeatingAlarm/index.html。首先,我们将从Manifest文件开始分析。 ... [详细]
  • 本文介绍了如何在Android应用中通过Intent调用其他应用的Activity,并提供了详细的代码示例和注意事项。 ... [详细]
  • 本文介绍了一种通过设置主题(Theme)来实现快速启动的Android引导页,并详细说明了如何避免因不同屏幕分辨率导致的图片拉伸问题。 ... [详细]
  • DirectShow Filter 开发指南
    本文总结了 DirectShow Filter 的开发经验,重点介绍了 Source Filter、In-Place Transform Filter 和 Render Filter 的实现方法。通过使用 DirectShow 提供的类,可以简化 Filter 的开发过程。 ... [详细]
author-avatar
fanguobiao
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有