elasticsearch - 编写脚本以从Elasticsearch获得独特的值(value)

标签 elasticsearch elasticsearch-painless

我想创建一个自定义的distinct函数,在该函数中,我可以编写具有多个字段名称的简单distincBy脚本,以将它们分隔在一起。无论如何,ElasticSearch中有实现此目标的方法。

最佳答案

我所做的是利用Terms Aggregation using Script从三个不同的字段构造键,然后将Terms Aggregation应用于此级联字段以提供所需的内容。

我创建了一个带有3个字段的示例索引,(文档类型为field1field2field3keyword)具有以下文档。您可以检查查询和结果部分以查看其显示方式。关键是结果部分中的keys是不同的。

样本文件

POST myfieldindex/mydocs/1
{
  "field1": "Football",
  "field2": "Premier League",
  "field3": "Chelsea"
}

POST myfieldindex/mydocs/3
{
  "field1": "Football",
  "field2": "Premier League",
  "field3": "Liverpool"
}

POST myfieldindex/mydocs/3
{
  "field1": "Football",
  "field2": "Premier League",
  "field3": "ManCity"
}

询问
POST myfieldindex/_search
{  
   "size":0,
   "aggs":{  
      "myagg":{  
         "terms":{  
            "script":{  
               "source":"doc['field1'].value + params.param + doc['field2'].value + params.param + doc['field3'].value",
               "lang":"painless",
               "params":{  
                  "param":","
               }
            }
         }
      }
   }
}

查询结果
{
  "took": 0,
  "timed_out": false,
  "_shards": {
    "total": 5,
    "successful": 5,
    "skipped": 0,
    "failed": 0
  },
  "hits": {
    "total": 3,
    "max_score": 0,
    "hits": []
  },
  "aggregations": {
    "myagg": {
      "doc_count_error_upper_bound": 0,
      "sum_other_doc_count": 0,
      "buckets": [
        {
          "key": "Football,Premier League,Chelsea",
          "doc_count": 1
        },
        {
          "key": "Football,Premier League,Liverpool",
          "doc_count": 1
        },
        {
          "key": "Football,Premier League,ManCity",
          "doc_count": 1
        }
      ]
    }
  }
}

因此,您可以在结果中看到key的构造方式(键是唯一的)。

让我知道这是否有帮助!

关于elasticsearch - 编写脚本以从Elasticsearch获得独特的值(value),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53076349/

相关文章:

django - 干草堆:针对多个模型的一个searchIndex

c# - NEST Elasticsearch高级排序

ruby-on-rails - 使用 Elasticsearch、Tire 和 Kaminari 进行分页

elasticsearch - 在 Elasticsearch 中无痛排序

elasticsearch - 为什么要使用无痛脚本将数组添加到数组?

elasticsearch - ElasticSearch-使用脚本提高得分

php - Elasticsearch 中可选的自父关系

elasticsearch - 在Elastic 5.4中选择正确的Tokenizer进行仿真包含类似查询

elasticsearch - 如何在Elasticsearch的子聚合中访问date_histogram键字段?

elasticsearch - 如何在写入ElasticSearch时使用更新API(无痛)连接对象而不是整个对象