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人