栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

spring data elasticsearch 使用 自定义分词/逗号分词 遇到的坑

spring data elasticsearch 使用 自定义分词/逗号分词 遇到的坑

目录

代码实现

遇到得坑


当我需要查询某一个字段,数据用“,”隔开得,例如 “1,2,4,5,6” 。 我们希望输入查询 4 或者 2,5 都能查出来。

使用spring data elasticsearch 的注解

@Data
@EqualsAndHashCode(callSuper = false)
@document(indexName = "shop", type = "product",shards = 1,replicas = 0)
@Setting(settingPath = "analyzer.json")
public class Product implements Serializable {
    private static final long serialVersionUID = -1L;
    @Id
    private Long id;

    //例如 1,2,5
    @Field(analyzer = "comma", searchAnalyzer = "comma", type = FieldType.Text)
    private String library;

    @Field(type = FieldType.Text)
    private String title;
}

自定义分词器:analyzer.json内容如下,把文件放在 resource下就可以了
 

{
  "index": {
    "number_of_replicas": "0"
  },
  "analysis": {
    "analyzer": {
      "comma": {
        "type": "pattern",
        "pattern":","
      }
    }
  }
}

然后用下面语句查询,就可以有想要得效果

   BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();
        queryBuilder.must(QueryBuilders.matchQuery("library", library).analyzer("comma"));
        Page page  = (Page) esExternalProductRepository.search(queryBuilder);

遇到得坑

1.使用未正确安装的分词器,导致自定义分词器不能使用

@Field(analyzer = "ik_max_word",type = FieldType.Text)
private String title;

一开始我以为服务端已经安装好了,中文分词器于是我就直接使用 analyzer="ik_max_word",项目在启动时,就会自动创建索引,但是遇到错误的分词器时,就会创建映射失败,但是整个项目也能正常运行。当后面调用

repository.save(object);

spring-data-elasticsearch 会创建一套默认的映射,也就是下面这里的注解不会生效了

@Field(analyzer = "comma", searchAnalyzer = "comma", type = FieldType.Text)
 private String library;

解决办法, 去掉不正确的 分词器,然后删掉索引库

elasticsearchTemplate.deleteIndex(indexName);

2.在已创建好索引库的前提下,然后加上自定义分词器,分词失败

当我改好代码准备运行时,发现怎么都没分词成功,后来各种折腾发现,

spring-data-elasticsearch 创建好字段后, 后面再怎么修改注解,索引的映射都不会改变(这个有待深入考证),也不会去导入 我们上面写好的 Setting。所以最后的解决办法也是删除索引库

elasticsearchTemplate.deleteIndex(indexName);

然后重新创建索引

elasticsearchTemplate.createIndex(EsExternalProduct.class); elasticsearchTemplate.putMapping(EsExternalProduct.class);

到此为止,坑解决完。

对于不用删除库的方法暂时还没研究出来,希望知道的朋友分享一下

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/677039.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号