java.lang.IllegalArgumentException: Fielddata is disabled on text fields by default. Set fielddata=t

java.lang.IllegalArgumentException: Fielddata is disabled on text fields by default. Set fielddata=true on [interests] in order to load fielddata in memory by uninverting the inverted index. Note that this can however use significant memory. Alternatively use a keyword field instead.

原因是:在做聚合时,尝试用text类型的字段做排序,text是需要分词的,分词的话首先字典很大,其次排序是对字典里的词进行排序而不是text类型的词,所以从es5开始就将text类型的字段的fielddata默认设置为false

so,可以解决的办法

PUT megacorp/_mapping/employee/
{
  "properties": {
    "interests": { 
      "type":     "text",
      "fielddata": true
    }
  }
}

last_name是你的聚类字段
返回结果提示为

  "acknowledged": true  

这里是我java代码聚合执行的结果
意思是interests里喜欢music的有2人,forestry1人,sports的1人

这里写图片描述

你可能感兴趣的:(idea)