aggregations 詳解1(概述)

aggregation分類

aggregations —— 聚合,提供了一種基于查詢條件來對數據進行分桶、計算的方法。有點類似于 SQL 中的 group by 再加一些函數方法的操作。

聚合可以嵌套,由此可以組成復雜的操作(Bucketing聚合可以包含sub-aggregation)。

聚合整體上可以分為 3 類:

1. Bucketing:桶分聚合:

  • 此類聚合執行的是對文檔分組的操作,把滿足相關特性的文檔分到一個桶里,即桶分。輸出結果往往是一個個包含多個文檔的桶。
  • 此類聚合會有一個關鍵字(field、script),以及一些桶分(分組)的判斷條件。執行聚合操作時候,文檔會判斷每一個分組條件,如果滿足某個,該文檔就會被分為該組(fall in)。

2. Metric:指標聚合:

  • 此類聚合是對文檔進行一些權值計算(比如求所有文檔某個字段的max值)。輸出結果往往是文檔的權值,相當于為文檔添加了一些統計信息。
  • 此類聚合基于特定字段(field)或腳本值(generated using scripts),計算聚合中文檔的權值。

3. Pipeline:管道聚合:

  • 對其它聚合操作的輸出及其關聯指標進行聚合。
  • 此類聚合的作用對象往往是桶,而不是文檔,是一種后期對每個分桶的一些計算操作。

應用場景

對于 3 中聚合,常見的應用場景如下流程:

buckets 聚合對文檔進行必要的歸類(桶分) ——> metric 聚合對每個桶進行一些額外的信息計算(如:max) ——> pipeline 聚合針對所有桶做一些桶層面的統計或計算

應用示例:

{"aggs" : {"sales_per_month" : {"date_histogram" : {              // bucket 聚合,按照月份進行分桶,每個月的歸屬一個桶"field" : "date","interval" : "month"},"aggs": {"sales": {"sum": {                       // metric 聚合,對每個桶類的 price 求和,即每月的銷售額"field": "price"}}}},"max_monthly_sales": {"max_bucket": {                 // pipeline 聚合,求所有桶中銷售額 sales 最大的值"buckets_path": "sales_per_month>sales" }}}
}

?

aggregation結構

聚合可以是父子(嵌套)關系聚合,buckets 聚合作為父,metric 聚合作為子。

聚合也可以是兄弟關系聚合,buckets 聚合在前,pipeline 聚合在后。

結構如下:

"aggregations" : {                                //定義聚合對象,也可用 "aggs""<aggregation_name>" : {                    //聚合的名稱,用戶自定義"<aggregation_type>" : {                //聚合類型,比如 "histogram"<aggregation_body>                  //每個聚合類型都有其自己的結構定義
          }[,"meta" : {  [<meta_data_body>] } ]?[,"aggregations" : { [<sub_aggregation>]+ } ]?    //可以定義多個 sub-aggregation
      }[,"<aggregation_name_2>" : { ... } ]*       //定義額外的多個平級 aggregation,只有 Bucketing 類型才有意義
}

?

轉載于:https://www.cnblogs.com/licongyu/p/5499388.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/271805.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/271805.shtml
英文地址,請注明出處:http://en.pswp.cn/news/271805.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

IDEA開發中,類的頭位置生成作者時間信息

點擊 File > Settings > File and Code Templates > Class按照圖中步驟添加如下信息 #if (${PACKAGE_NAME} && ${PACKAGE_NAME} ! "")package ${PACKAGE_NAME};#end #parse("File Header.java") /** * Author WangZeyu * Date ${…

提現接口網站 php,API提現接口

>獲取提現積分的類型&#xff0c;在后臺可以設置某種積分可被提現&#xff0c;此處獲取的數據為可提現積分的類型~~~[api]get:/index.php/accounts/Apipoint/member_withdrawal_listint:type 0#是否智能限制提現積分類型&#xff0c;0&#xff1a;不智能&#xff0c;1&#…

數據庫:PostgreSQL 和 MySQL對比

比較版本&#xff1a;PostgreSQL 11 VS MySQL5.7&#xff08;innodb引擎&#xff09; Oracle官方社區版版權情況&#xff1a;PostgreSQL 11&#xff08;免費開源&#xff09;、MySQL5.7 Oracle官方社區版&#xff08;免費開源&#xff09; 1. CPU限制 PGSQL沒有CPU核心數限制&a…

C#獲取當前系統磁盤符、系統目錄、桌面等

1.獲取方式如下 Environment.SpecialFolder中定義了許多常用的目錄 //獲取當前系統磁盤符方法1&#xff0c;返回&#xff1a;C: string path Environment.GetEnvironmentVariable("systemdrive"); //獲取當前系統磁盤符方法2,返回&#xff1a;C: string path Envir…

MAC電腦常用效率工具推薦

??作者主頁&#xff1a;IT技術分享社區 ??作者簡介&#xff1a;大家好,我是IT技術分享社區的博主&#xff0c;從事C#、Java開發九年&#xff0c;對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽&#xff1a; 數據庫領域優質創作者&#x1f3c6;&#x…

Java String類型轉換成Date日期類型

//格式化數據 SimpleDateFormat sdf new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String format sdf.format(new Date()); System.out.println(format);//String格式的數據轉化成Date格式 String timeStr "2019-07-09 03:34:56 "; Date parse sdf.pa…

docker php 安裝swoole,swoole(1)使用docker安裝swoole環境

1.下載鏡像pull php 鏡像docker pull php:7.3-alpine3.8創建容器docker run -it --name test php:7.3-alpine3.8 sh2.進入容器安裝swoole# 安裝依賴的第三方包echo http://mirrors.ustc.edu.cn/alpine/v3.7/main > /etc/apk/repositories && \echo http://mirrors.u…

插件書寫示例

正常模態框代碼 <!DOCTYPE html> <html lang"en"> <head><meta charset"utf-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-wid…

MAC電腦8款常用設計工具推薦

目錄 1、Sketch 3 2、Affinity Designer 3、Framer 4、PaintCode 5、Hype 3 Professional 6、Pixave 2 7、Iconjar 8、Sip for Mac and iPhone 1、Sketch 3 Sketch是完全滿足我上面4條選擇條件的一款UI設計工具&#xff0c;前文第50頁已經提到過相關內容。 2、Affinity Designe…

matlab the installer cannot read,MATLAB安裝 The installer cannot read the mwinstall.dll… | 學步園...

前提&#xff1a;安裝前的文件 的 目錄 不需含有 中文安裝MATLAB7時彈出以下警告對話框&#xff0c;顯示“ The installer cannot read the mwinstall.dll file, This is probably due to a CD reader which can only read files with an eight.three naming convention. Pleas…

專家觀點:即使在云中 硬件同樣至關重要

英特爾最近發布了新一代企業級CPU。第四代E5和E7CPU確實有些與眾不同之處&#xff1a;更多的緩存、更多的內核、更快更多的RAM。但是大家沒有發現這款產品還有一個特別的地方。 也許一切都與云有關&#xff0c;我們已經告別以前的硬件。你可能認為IT命令結構級別越高&#xff0…

matlab怎么安裝compiler,關于MATLAB中compiler配置問題

按照大家的方法進行了系統配置&#xff0c;下載安裝了SDK7.1&#xff0c;可運行mex setup之后還是一直彈出No supported SDK or compiler was found on this computer.Welcome to mex -setup. This utility will help you set upa default compiler. For a list of supported…

計算機硬件:內存條的基礎知識筆記

在電腦硬件中&#xff0c;CPU、顯卡、內存均三者是重中之重&#xff0c;所以我們在選擇這些核心硬件一定要慎重。今天給大家分享一下關于的電腦內存基礎知識&#xff0c;讓更多的裝機朋友們可以更好的學習內存相關知識。 史上最易懂的電腦內存基礎知識 內存條的基本概念&#x…

數獨Sudoku

數獨&#xff08;すうどく&#xff0c;Sūdoku&#xff09;&#xff0c;是源自18世紀瑞士發明&#xff0c;流傳到美國&#xff0c;再由日本發揚光大的一種數學游戲。是一種運用紙、筆進行演算的邏輯游戲。玩家需要根據99盤面上的已知數字&#xff0c;推理出所有剩余空格的數字&…

電腦CPU選購的幾個指標

CPU的概念介紹 CPU是Central Processing Unit(中央處理器)的縮寫&#xff0c;CPU的詳細參數包括內核結構&#xff0c; 主頻&#xff0c;外頻&#xff0c;倍頻&#xff0c;接口&#xff0c;緩存&#xff0c;多媒體指令集&#xff0c;制造工藝&#xff0c;電壓&#xff0c;封裝形…

idea生成方法注釋的正確方法

生成方法注釋 1.打開File -> Settings 2.Editor -> Live Templates -> 點擊右邊加號為自己添加一個Templates Group -> 然后選中自己的Group再次點擊加號添加Live Templates 重點&#xff1a;Abbreviation那里不要用/開頭的&#xff01;&#xff01;&#xff01; …

php linux 緩存文件,Linux下搭建網站提示緩存文件寫入失敗怎么辦?

Linux下搭建網站提示緩存文件寫入失敗時該怎么處理&#xff1f;基于ThinkPHP框架及Linux環境搭建的網站&#xff0c;經常會遭遇緩存文件寫入失敗的錯誤提示&#xff0c;即便是現在流行的P2P網站程序便是如此&#xff0c;具體解決方法請看下文。Linux下搭建網站提示緩存文件寫入…

什么是CharSequence

CharSequence是一個接口&#xff0c;比較常見的String、StringBuilder、StringBuffer都實現了這個接口。 當我們看到一個API里面有CharSequence的時候&#xff0c;它也是可以被其子類代替的&#xff0c;一般用String代替即可。

你真的了解顯卡嗎?顯卡基礎知識大掃盲

??作者主頁&#xff1a;IT技術分享社區 ??作者簡介&#xff1a;大家好,我是IT技術分享社區的博主&#xff0c;從事C#、Java開發九年&#xff0c;對數據庫、C#、Java、前端、運維、電腦技巧等經驗豐富。 ??個人榮譽&#xff1a; 數據庫領域優質創作者&#x1f3c6;&#x…

Servlet的運行方式

通常我們運行servlet需要在web.xml配置文件中&#xff0c;注冊我們寫好的servlet以及其對應的訪問路徑。 在學習web開發中&#xff0c;有一種不需要配置便可以直接對servlet進行配置的方式&#xff0c;在web.xml文件中添加如下代碼&#xff1a; <servlet><servlet-nam…