Elasticsearchトップ選手は(6) - クイック実際のケースを起動します。グループを+平均+ソートや他の重合分析(c)で

1.各タグ内のアイテムの数を計算

GET / eコマース/製品/ _search

{

     「aggs」:{

          「group_by_tags」:{

                 「用語」:{「フィールド」:」タグ」}

           }

     }

}

画像

fielddateプロパティのテキストフィールドがtrueに設定されています

PUT / eコマース/ _mapping /製品

{

      「プロパティ」:{

            「タグ」:{

                「タイプ」:」テキスト」、

                「fielddata」:真

           }

      }

}

画像

再実行コマンドパケット

「サイズ」:0

結果は、データの分析に関する情報を表示重合分析した後にのみ返されないことがあります

画像


2. yagao商品を含む名前、各タグで算出した商品の数量

GET /ecommerce/product/_search
{
   "size": 0,
   "query": {
     "match": {
       "name": "yagao"
     }
   },
   "aggs": {
     "group_by_tags": {
       "terms": {
         "field": "tags"
       }
     }
   }
}

画像

结果一样,因为每个商品name中都包含有yagao

3.先分组,再算每组的平均值,计算每个tag下的商品的平均价格

GET /ecommerce/product/_search

{

      “size”:0,

      “aggs”:{

            “group_by_tags”:{

                     “terms”:{“fiedd”:”tags”},

                     “aggs”:{

                           “avg_price”:{

                                    “avg”:{“field”:”price”}

                             }

                     }

             }

      }

}

画像


4.在3的基础上,按照平均价格进行排序

GET /ecommerce/product/_search

{

      “size”:0,

      “aggs”:{

            “group_by_tags”:{

                     “terms”:{“fiedd”:”tags”,“order”:{“avg_price”:”desc”}},

                     “aggs”:{

                           “avg_price”:{

                                    “avg”:{“field”:”price”}

                             }

                     }

             }

      }

}

画像

5.按照指定的价格范围区间进行分组,然后在每组内按照tag进行分组,最后再计算每组的平均价格

GET /ecommerce/product/_search
{
   "size": 0,
   "aggs": {
   "group_by_price": {
       "range": {
         "field": "price",
         "ranges": [
           {
             "from": 0,
             "to": 20
           },
           {
             "from": 20,
             "to": 40
           },
           {
             "from": 40,
             "to": 50
           }
         ]
       },
       "aggs": {
         "group_by_tag": {
           "terms": {
             "field": "tags",
             "order": {
               "avg_by_price": "DESC"
             }
           }、
           "aggs":{
             "avg_by_price":{
               "平均":{
                 "フィールド": "価格"
               }
             }
           }
         }
       }
     }
   }
}

画像

おすすめ

転載: www.cnblogs.com/Mr-WangYue/p/11518866.html