ElasticSearch 模糊查询 wildcard 的一些问题(模糊查询不精准问题)

我们都知道在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 + "*"));

是不是很简单!以上就是全部内容了,期望能对你有所帮助

评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值