org.elasticsearch.index.mapper.MapperParsingException: analyzer [ik_max_word] not found for field [t

1、问题:
运行 springboot 项目,idea 控制台报错:
elasticsearch 创建索引时遇到 analyzer [ik_max_word] not found for field [name] ;

2020-11-20 20:01:00.993 ERROR 2242 — [ restartedMain] .d.e.r.s.AbstractElasticsearchRepository : failed to load elasticsearch nodes : org.elasticsearch.index.mapper.MapperParsingException: analyzer [ik_max_word] not found for field [title]

2、原因
IK分词器插件 未安装;

未安装原因:mac brew 安装的 elasticsearch 版本只有两个选择,为适应项目版本,于是安装了 elasticsearch 6.8.13 ,才发现,这个版本没有 ik 分词器。☹️

源文转自:
解决办法

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: fieldType = FieldType.TEXT 表示该字段是文本类型。 analyzer = Analyzer.IK_SMART 表示使用 IK_SMART 分词器对该字段进行分词。 searchAnalyzer = Analyzer.IK_MAX_WORD 表示使用 IK_MAX_WORD 分词器对该字段进行搜索。 ### 回答2: 根据提供的信息,我理解您遇到了一个问题:在进行es特殊字符查询时无法查找到结果。根据您提供的字段的设置,将为您解释可能的原因。 首先,您指定了字段类型为FieldType.TEXT,这意味着该字段将被分析器处理为文本类型数据。接下来,您指定了分析器为Analyzer.IK_SMART,搜索分析器为Analyzer.IK_MAX_WORDIK分析器是一种面向中文文本的分析器,可以将文本拆分成合适的词语以便更准确的进行搜索。IK分析器有两种模式可供选择:IK_SMART和IK_MAX_WORDIK_SMART模式是一种智能模式,会尽量将文本进行最准确的拆分,以尽可能包含更多的搜索结果。而IK_MAX_WORD模式会将文本切分为更多的词语,以尽可能获取更多的搜索结果。 然而,如果您遇到特殊字符查询不到结果的情况,可能是因为您所使用的查询方式不适用于特殊字符。在进行使用特殊字符的查询时,可能需要使用其他的操作符或查询方法来确保能够正确匹配到特殊字符。例如,您可以使用正则表达式查询来匹配特殊字符,或者使用原始查询语法来确保特殊字符被正确解析。 另外,还有一种可能性是特殊字符在被分析器处理时发生了改变,导致不能正确匹配到您预期的结果。这时您可以尝试更改分析器配置或者选择其他的分析器来处理特殊字符。 总结来说,要在es特殊字符查询中获得正确的结果,您需要确保使用合适的操作符或查询方法,并确保您所选择的分析器正确处理特殊字符。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值