Java创建elasticsearch的model时,如何配置使用ik分词器?

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

@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。

如果满意,请打赏博主任意金额,感兴趣的在微信转账的时候,添加博主微信哦。 请下方留言吧,可与博主*讨论哦。

支付宝 微信
Java创建elasticsearch的model时,如何配置使用ik分词器? Java创建elasticsearch的model时,如何配置使用ik分词器?