问题描述
当对path字段进行模糊查询时,当查询值内有特殊字符时,es 无法返回有效数据。
query := es.NewBoolQuery().query.Must(es.NewWildcardQuery("path", wildcardItem(Path)))
原因猜测
1、特殊字符需要转义?
2、分词了导致搜索不到?
解决办法
1、查看api源码发现,api会自动转义,因此排除1原因
2、检查es mapping,发现path字段的type是text类型,text类型字段存储时会先进行分词,将分词后的词组存入索引,因此查询时就会出现问题了。
解决方法
a) reindex,重新创建索引,很麻烦
b) 查询时加上.keyword后缀
query := es.NewBoolQuery()
query.Must(es.NewWildcardQuery("path.keyword", wildcardItem(req.Path)))