热门标签 | 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


推荐阅读
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
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社区 版权所有