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。
如果满意,请打赏博主任意金额,感兴趣的在微信转账的时候,添加博主微信哦。 请下方留言吧,可与博主*讨论哦。
支付宝 | 微信 |
---|---|