elasticsearch 官方API翻譯 聚合

聚合

在使用查詢query的時候讯私,可以使用 aggregations 框架來聚合數(shù)據(jù)。只需要在query語句構建的時候使用aggregations塊良狈。

一個aggregation可以被視作一個在doc集合的基礎上做分析的單元窥浪。它執(zhí)行上下文信息定義了這個集合。比如說search請求的query/filters的上下文壮啊,會被用來執(zhí)行頂層的聚合。

有許多不同類型的aggregations撑蒜,他們可以實現(xiàn)不同的需求歹啼,并且有不相同的輸出∽ぃ可以將這些聚類分為4個大家族

  • bucketing : 桶
    這個系列的聚合狸眼,可以構建桶,每個桶關聯(lián)一個key和一個criterion浴滴。 當執(zhí)行聚合時拓萌,根據(jù)標準來評估,在上下文中的文檔集合中的每個文檔升略,并且當匹配這個標準時微王,該文檔被認為“落入”相關桶。 在聚合過程結束時品嚣,我們將最終得到一個桶列表炕倘,每個桶都有一組“屬于”這個桶的文檔。

  • Metric : 指標
    基于一個doc集合跟蹤和計算指標翰撑。

  • Matrix:矩陣
    操作多個字段罩旋,并且基于從requested文檔字段中抽取的值,產(chǎn)生一個矩陣眶诈。這種類型的聚合不支持腳本涨醋。

  • Pipeline:管道
    聚合其他聚合的輸出或者相關的指標。

由于每個桶有效地定義了一個文檔集(所有文檔屬于存儲桶)逝撬,所以可以潛在地關聯(lián)存儲桶級別的聚合东帅,并且它們將在該存儲桶的上下文中執(zhí)行。 這是聚合的真正力量在哪里:聚合可以嵌套球拦!

bucket 聚合可以包含子聚合(bucket 或 metric)。 子聚合將根據(jù)父聚合生成的bucket進行計算。 嵌套聚合的級別/深度沒有硬限制(可以在“父”聚合下嵌套聚合坎炼,本身就是另一個更高層聚合的子聚合)愧膀。

聚合的結構

下面的片段是聚合的基本結構:

"aggregations" : {
    "<aggregation_name>" : {
        "<aggregation_type>" : {
            <aggregation_body>
        }
        [,"meta" : {  [<meta_data_body>] } ]?
        [,"aggregations" : { [<sub_aggregation>]+ } ]?
    }
    [,"<aggregation_name_2>" : { ... } ]*
}

JSON中的aggregations對象(也可以使用aggs)將要進行聚合計算。用戶可以為每個聚合定義一個邏輯名稱(例如谣光,如果聚合計算平均價格檩淋,可以將其命名為avg_price)。這些邏輯名稱也將用于唯一標識響應中的聚合萄金。每個聚合都有一個特定類型(上述代碼片段中的<aggregation_type>)蟀悦,通常是body里的第一個key。每種類型的聚合根據(jù)聚合的性質來定義了其自己的body(例如氧敢,特定字段上的平均聚合將定義將計算平均值的字段)日戈。在聚合類型定義的相同級別,可以選擇定義一組附加聚合孙乖,盡管如果您定義的聚合具有壓力性質浙炼,這僅僅是有意義的。在這種情況下唯袄,您將在針對集合聚合級別定義的子聚合計算所有由聚合聚合構建的桶弯屈。例如,如果在范圍聚合范圍內定義了一組聚合恋拷,則將針對定義的范圍值來計算子聚合资厉。

Values Source

一些聚合基于另一個聚合的輸出。我們?yōu)橐粋€聚合設置了field蔬顾,這個聚合的結果中包含文檔中field的值宴偿,通常,values會從這些值中抽取阎抒。也可以定義一個script來為每一個doc生成一個值酪我,用。
如果為聚合設置了且叁,field和script2個字段都哭,script將被當作value script對待。像普通的scripts在doc級別被評估一樣逞带,value script在value級別被評估欺矫。在這種模式下,value重field中取得展氓,script被應用于 “transformation” 這些value上穆趴。

Elasticsearch使用mapping中的field類型來知道如何運行聚合,并且格式化響應遇汞。然后有2中清空未妹,es不能高清楚這些信息簿废,沒有別映射的的字段和存腳本。在這種情況下络它,可以使用value_type選項來制定類型族檬。可用的類型是string化戳,long(適用于所有的integer類型)单料,double,date,ip和boolean。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末点楼,一起剝皮案震驚了整個濱河市扫尖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掠廓,老刑警劉巖换怖,帶你破解...
    沈念sama閱讀 223,002評論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異却盘,居然都是意外死亡狰域,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評論 3 400
  • 文/潘曉璐 我一進店門黄橘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來兆览,“玉大人,你說我怎么就攤上這事塞关√剑” “怎么了?”我有些...
    開封第一講書人閱讀 169,787評論 0 365
  • 文/不壞的土叔 我叫張陵帆赢,是天一觀的道長小压。 經(jīng)常有香客問我,道長椰于,這世上最難降的妖魔是什么怠益? 我笑而不...
    開封第一講書人閱讀 60,237評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮瘾婿,結果婚禮上蜻牢,老公的妹妹穿的比我還像新娘。我一直安慰自己偏陪,他們只是感情好抢呆,可當我...
    茶點故事閱讀 69,237評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著笛谦,像睡著了一般抱虐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上饥脑,一...
    開封第一講書人閱讀 52,821評論 1 314
  • 那天恳邀,我揣著相機與錄音讶踪,去河邊找鬼夸浅。 笑死涡驮,一個胖子當著我的面吹牛沾凄,可吹牛的內容都是我干的。 我是一名探鬼主播鳄抒,決...
    沈念sama閱讀 41,236評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼椰弊!你這毒婦竟也來了许溅?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 40,196評論 0 277
  • 序言:老撾萬榮一對情侶失蹤秉版,失蹤者是張志新(化名)和其女友劉穎贤重,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體清焕,經(jīng)...
    沈念sama閱讀 46,716評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡并蝗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,794評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了秸妥。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片滚停。...
    茶點故事閱讀 40,928評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖粥惧,靈堂內的尸體忽然破棺而出键畴,到底是詐尸還是另有隱情,我是刑警寧澤突雪,帶...
    沈念sama閱讀 36,583評論 5 351
  • 正文 年R本政府宣布起惕,位于F島的核電站,受9級特大地震影響咏删,放射性物質發(fā)生泄漏惹想。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,264評論 3 336
  • 文/蒙蒙 一督函、第九天 我趴在偏房一處隱蔽的房頂上張望嘀粱。 院中可真熱鬧,春花似錦侨核、人聲如沸草穆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,755評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽悲柱。三九已至,卻和暖如春些己,著一層夾襖步出監(jiān)牢的瞬間豌鸡,已是汗流浹背嘿般。 一陣腳步聲響...
    開封第一講書人閱讀 33,869評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留涯冠,地道東北人炉奴。 一個月前我還...
    沈念sama閱讀 49,378評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像蛇更,于是被迫代替她去往敵國和親瞻赶。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,937評論 2 361

推薦閱讀更多精彩內容