我们都知道在ES中如果我们想要实现MySQL中的like查询的时候可以使用wildcard 通配符来进行操作。其中?代表任意一个字符*代表任意的一个或多个字符。操作语句如下
#模糊查询,比如查询李世民
GET booke/member/_search
{"query": {
"wildcard":{
"senderName": "李*"
}
}
}
#模糊查询,比如查询李政,PS:查不出李世民
GET booke/member/_search
{"query": {
"wildcard":{
"senderName": "李?"
}
}
}
在Java代码中可以这样使用
boolQueryBuilder.should(QueryBuilders.wildcardQuery("word", "*" + obj + "*"));
但是在最近的项目中我遇到一个问题,我在使用模糊查询的时候比如我想查“马克思”这个名字的时候,我输入“马*”或者“*思”的时候都能查出来但是输入“马克*”或者直接“马克思”的时候却查不出来,后面经过查询官方文档的时候才发现,我们在使用wildcard进行模糊查询的时候他默认是会你要查询的字段进行分词查询的 所以“马克思”这三个字很可能就被分词成了三个字 但是却没有连起来的分词 这就导致你查询不出来的原因。
解决办法:
我们在使用wildcard模糊查询的时候如果不想对字段内容进行分词查询的话可以将内容变成keyword模式去查询,这样我们进行查询的时候就不会进行分词查询了
代码如下
#模糊查询,比如查询李世民
GET booke/member/_search
{"query": {
"wildcard":{
"senderName.keyword": "李*"
}
}
}
JAVA代码:
boolQueryBuilder.should(QueryBuilders.wildcardQuery("word.keyword", "*" + obj + "*"));
是不是很简单!以上就是全部内容了,期望能对你有所帮助