Java

Java创建elasticsearch的model时,如何配置使

2018-11-12  本文已影响14人  王月亮17

在需要分词的属性上面加注解:

@Field(type = FieldType.text, analyzer = "ik_max_word", searchAnalyzer = "ik_max_word")

即可。
例如:

@Document(indexName = "people_v1", type = "peopleV1")
public class People{
    @Id
    private Integer id;
    @Field(type = FieldType.text, analyzer = "ik_max_word", searchAnalyzer = "ik_max_word")
    private String name;
    ……
}

analyzer和searchAnalyzer中保持一直,ik_max_word可以改成ik_smart。
ik_max_word和ik_smart的区别在于,ik_max_word会采用穷尽式的分词,比如“我爱北京天安门”,可能会分出“我”,“我爱”,“北京”,“天”,“天安门”等,而ik_smart分的会比较粗,如上语句可能会分出“我爱”,“北京”,“天安门”这样。
如果要搜索出的结果尽可能全,可以使用ik_max_word,如果需要结果尽可能精确,可以使用ik_smart。

上一篇 下一篇

猜你喜欢

热点阅读