ES/OS:存储桶键子字符串上的术语聚合

发布于 2025-01-15 17:32:47 字数 1001 浏览 4 评论 0原文

我有以下查询结果,我想计算分隔符 : 之后的子字符串

                "agg_by_script" : {
                  "doc_count_error_upper_bound" : 0,
                  "sum_other_doc_count" : 0,
                  "buckets" : [
                    {
                      "key" : "mic:cse",
                      "doc_count" : 2
                    },
                    {
                      "key" : "ggl:cse",
                      "doc_count" : 20
                    },
                    {
                      "key" : "amz-ret",
                      "doc_count" : 1
                    },
                    {
                      "key" : "ety:onr",
                      "doc_count" : 1
                    }
                  ]
                }

,从这个结果中我实际上想要下面的结果

"agg_by_company_type" : {
 "buckets" : [
 {
    "key" : "ret",
     "doc_count" : 1
 },
 {
   "key" : "cse",
    "doc_count" : 2
 },
 {
   "key" : "onr",
    "doc_count" : 1
 }
]

I have the following query result and I want to count the substring after delimiter :

                "agg_by_script" : {
                  "doc_count_error_upper_bound" : 0,
                  "sum_other_doc_count" : 0,
                  "buckets" : [
                    {
                      "key" : "mic:cse",
                      "doc_count" : 2
                    },
                    {
                      "key" : "ggl:cse",
                      "doc_count" : 20
                    },
                    {
                      "key" : "amz-ret",
                      "doc_count" : 1
                    },
                    {
                      "key" : "ety:onr",
                      "doc_count" : 1
                    }
                  ]
                }

And from this result I actually want below

"agg_by_company_type" : {
 "buckets" : [
 {
    "key" : "ret",
     "doc_count" : 1
 },
 {
   "key" : "cse",
    "doc_count" : 2
 },
 {
   "key" : "onr",
    "doc_count" : 1
 }
]

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

回忆凄美了谁 2025-01-22 17:32:47

您可以通过脚本使用术语聚合。这是一个示例查询:

{
  "size": 0,
  "aggs": {
    "agg_by_company_type": {
      "terms": {
        "script": """
          String txt = doc['FieldName'].value;
          if(txt.indexOf(':') > -1 ) {
            return txt.splitOnToken(':')[1];
          }
          else if(txt.indexOf('-') > -1 ) {
            return txt.splitOnToken('-')[1];
          }
          else {
            return txt;
          }
        """
      }
    }
  }
}

或者您可以根据需要在脚本中执行任何字符串操作。

You can use terms aggregation with script. This is an example query:

{
  "size": 0,
  "aggs": {
    "agg_by_company_type": {
      "terms": {
        "script": """
          String txt = doc['FieldName'].value;
          if(txt.indexOf(':') > -1 ) {
            return txt.splitOnToken(':')[1];
          }
          else if(txt.indexOf('-') > -1 ) {
            return txt.splitOnToken('-')[1];
          }
          else {
            return txt;
          }
        """
      }
    }
  }
}

Or you can do any string operation in the script according to your needs.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文