美文网首页Java
Java创建elasticsearch的model时,如何配置使

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

作者: 王月亮17 | 来源:发表于2018-11-12 18:53 被阅读14次

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

@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时,如何配置使

    本文链接:https://www.haomeiwen.com/subject/ryocfqtx.html