(转)es 聚合查询并返回每个组的数据

转自: https://blog.csdn.net/ywdhzxf/article/details/84878760

 

需求
我现在是有一个这样的需求, 我需要在es里面按照 cityarea 进行分组(group by), 并且每个 cityarea的组 需要展示 按照时间排序的前10条, 状态全部为1的数据

实现
  {
    "query": {
      "bool": {
        "must": [
          {
            "term": {
              "status": "1"         # 筛选条件, 状态为 1 的
            }
          }
        ]
      }
    },
    "from": 0,
    "size": 10,
    "aggs": {
      "top_score": {                 ## 聚合名
        "terms": {
          "field": "cityarea",       ## 按照cityarea 进行分组
          "size": 30                 ## 注意: 这个size 是必填的, 因为不填默认是10, 也就是说如果我有 11个cityarea组的话, 在这只能分10个组, 最后一组不显示,
        },                                   个人建议根据分组情况写一个较大的值
        "aggs": {
          "top_score_hits": {
            "top_hits": {
              "_source": [
                "name"              ## 只展示name字段, 按照自己的需求来就行
              ],
              "size": 10,           ## 这个size是每个组展示多少条数据, 默认是10
              "sort": {
                "first_time": {
                  "order": "desc"   ## 按照时间进行排序
                }
              }
            }
          }
        }
      }
    }
  }
————————————————
版权声明:本文为CSDN博主「小僵尸打字员」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ywdhzxf/article/details/84878760

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/330398.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java程序员被误导的一个概念,Set也可以有序

转载自 java程序员被误导的一个概念,90%人不知道我们经常听说List是有序且重复的,Set是无序不重复的。这里有个误区,这里说的顺序有两个概念,一是按添加的顺序排列,二是按自然顺序a-z排列。Set并不是无序的&#xff0c…

es7 bulk api 批量插入es

post localhost:9200/cuiji/_doc/_bulk {"index":{}} {"RCRD_ID":"RD_TR_001", "CUST_NUM":"CUSTA", "LAST_MODIFY_TIME":"2020-07-18 00:00:50", "NOTE_CONTENT":"催记A001"} {…

TreeSet的null值与元素类型的约束

一、TreeSet Java的TreeSet通过TreeMap来实现,具有自然排序的功能。 在默认情况下,元素不允许为null值,元素必须是相同类型,元素必须实现了Comparable接口;否则会出现java.lang.ClassCastException。 可以通过设置Comp…

转-HTTPClient调用https请求,通过基本认证用户名密码(Basic Auth)

转自: https://blog.csdn.net/qq_27605885/article/details/79131483 本文来源是Apache官网例子:http://hc.apache.org/httpcomponents-client-4.5.x/httpclient/examples/org/apache/http/examples/client/ClientAuthentication.java 之前找过很多博客…

你知道void和Void的区别吗

转载自 你知道void和Void的区别吗 区别 void 用于无返回值的方法定义。 Void Void是void的包装方法,和其他基础类型的包装方法不同是Void不能被实例化,Void还可用于一直返回null的方法或者返回null的泛型。 代码示例

httpclient es action_request_validation_exception validation failed 1 no requests added原因和解决方法

【README】 批量插入数据到es,报错如下; action_request_validation_exception validation failed 1 no requests added 原因: 在请求头设置报文为 json格式,但报文并非json格式, 如 java字符串: post l…

POJ1321(DFS)

Problem Descrption 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别。要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的…

关于java流的几个概念:IO、BIO、NIO、AIO,有几个人全知道?

转载自 关于java流的几个概念:IO、BIO、NIO、AIO,有几个人全知道? 关于同步、阻塞的知识我之前的文章有介绍,所以关于流用到这些概念与之前多线程用的概念一样。 下面具体来看看java中的几种流 IO/BIO BIO就是指IO,即…

转:字符串和编码

转: https://www.liaoxuefeng.com/wiki/1016959663602400/1017075323632896 字符编码 我们已经讲过了,字符串也是一种数据类型,但是,字符串比较特殊的是还有一个编码问题。 因为计算机只能处理数字,如果要处理文本&…

HDU2067(卡特兰数)

Problem Descrption 小兔的叔叔从外面旅游回来给她带来了一个礼物,小兔高兴地跑回自己的房间,拆开一看是一个棋盘,小兔有所失望。不过没过几天发现了棋盘的好玩之处。从起点(0,0)走到终点(n,n)的最短路径数是C(2n,n),现在小兔又想…

JAVA元注解@interface详解(@Target,@Documented,@Retention,@Inherited)

转载自 JAVA元注解interface详解(Target,Documented,Retention,Inherited) jdk1.5起开始提供了4个元注解,用来定义自定义注解的注解,它们分别是: Target 指定注解使用的目标范围(类、方法、字段等),其参考值…

转:字符编码笔记:ASCII,Unicode 和 UTF-8

转: http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf-8.html 作者: 阮一峰 日期: 2007年10月28日 今天中午,我突然想搞清楚 Unicode 和 UTF-8 之间的关系,就开始查资料。 这个问题比我想象的复杂&am…

HDU2068(错列排序)

Problem Descrption 今年暑假杭电ACM集训队第一次组成女生队,其中有一队叫RPG,但做为集训队成员之一的野骆驼竟然不知道RPG三个人具体是谁谁。RPG给他机会让他猜猜,第一次猜:R是公主,P是草儿,G是月野兔;第二次猜&…

Java码农必须掌握的循环删除List元素的正确方法

转载自 Java码农必须掌握的循环删除List元素的正确方法 首先看下下面的各种删除list元素的例子 public static void main(String[] args) {List<String> list new ArrayList<>(Arrays.asList("a1", "ab2", "a3", "ab4",…

es dsl多条件组合查询(转)

【README】在不评分的情况下&#xff0c; 推荐使用filter 过滤查询&#xff0c;因为不评分&#xff0c;查询性能优于评分性能&#xff1b; 转&#xff1a;https://www.elastic.co/guide/cn/elasticsearch/guide/current/combining-queries-together.html 下面截图是我认为最有…

Java集合从菜鸟到大神演变

转载自 Java集合从菜鸟到大神演变 先来看一张集合概况图&#xff0c;这里从上到下列举了几个最经常用的集合 1、集合接口 java.util.Collection 是一个集合接口。它提供了对集合对象进行基本操作的通用接口方法。Collection接口在Java 类库中有很多具体的实现。Collection接口的…

转:Java并发编程与高并发解决方案(一)

转&#xff1a; https://blog.csdn.net/m0_37819279/article/details/81154126 首先介绍连接池 1&#xff1a;ExecutorService是Executor直接的扩展接口&#xff0c;也是最常用的线程池接口&#xff0c;我们通常见到的线程池定时任务线程池都是它的实现类。 2&#xff1a;Exe…

HDU1864(01背包)

Problem Descrption 现有一笔经费可以报销一定额度的发票。允许报销的发票类型包括买图书&#xff08;A类&#xff09;、文具&#xff08;B类&#xff09;、差旅&#xff08;C类&#xff09;&#xff0c;要求每张发票的总额不得超过1000元&#xff0c;每张发票上&#xff0c;单…

转:并发与并行的区别

转&#xff1a; https://www.jianshu.com/p/b11e251d3dc7 并发:一个处理器同时处理多个任务。&#xff08;concurrency&#xff09; 单个cpu逻辑上同时处理多个任务&#xff1b;并行:多个处理器或者是多核的处理器同时处理多个不同的任务. &#xff08;parallelism&#xff0…

面试必问-几种线程安全的Map解析

转载自 面试必问&#xff0d;几种线程安全的Map解析HashMap线程安全的吗&#xff1f;Java中平时用的最多的Map集合就是HashMap了&#xff0c;它是线程不安全的。看下面两个场景&#xff1a;1、当用在方法内的局部变量时&#xff0c;局部变量属于当前线程级别的变量&#xff0c;…