您当前的位置: 首页 >  ar

qq_34412985

暂无认证

  • 0浏览

    0关注

    1061博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

ElasticSearch的排序和聚类时出现fielddata=true问题

qq_34412985 发布时间:2019-12-14 20:53:53 ,浏览量:0

遇到这个错误是因为你尝试对一个text类型的字段做排序,而text类型的字段是要分词的。 一来词典很大,性能会很差;二来排序结果是词典里的词,而并非整个text的内容。 出于这2点原因,ES5.x以后对于text类型默认禁用了fielddata,防止对text字段一些错误的操作(排序,聚合,script)而给heap造成很大的压力。   如果一定有对该字段按照文本字母序做排序的需求,可以将该字段定义为multi-filed,例如:

PUT my_index {   "mappings": {     "my_type": {       "properties": {         "city": {           "type": "text",           "fields": {             "raw": {                "type":  "keyword"             }           }         }       }     }   } }

上面的city是text类型,适合做全文搜索,然后排序的时候可以用其keyword类型即city.raw。  这样排序结果是正确的,并且keyword字段是通过doc values排序的,内存消耗远小于fielddata。

关注
打赏
1653291990
查看更多评论
立即登录/注册

微信扫码登录

0.0410s