目录
当我需要查询某一个字段,数据用“,”隔开得,例如 “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<EsExternalProduct> page = (Page<EsExternalProduct>) 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);
到此为止,坑解决完。
对于不用删除库的方法暂时还没研究出来,希望知道的朋友分享一下