gpt4 book ai didi

php - AWS中ElasticSearch通配符查询和空格的问题

转载 作者:行者123 更新时间:2023-12-02 22:19:33 24 4
gpt4 key购买 nike

我们最近集成了ElasticPress for WooCommerce,并对其代码进行了一些改进(通过其过滤器),但遇到了一些似乎是ElasticSearch API局限性的事情。我们在搜索订单时对发送到 flex 搜索引擎的查询进行了修改,以使搜索词可以用作部分搜索(类似于SQL中的LIKE语句)。

它工作正常,除非查询中有特殊符号(如空格或@符号)。我读过可以通过转义特殊字符来避免这种情况,但是我也没有运气。

我正在使用通配符查询,并且我尝试用其转义版本替换空格,甚至是? token (应与任何单个字符匹配)。也没有运气。

该查询有效:

"query": {
"wildcard": {
"meta._billing_full_name.value": "*manish*"
}
}

这也是
"query": {
"wildcard": {
"meta._billing_full_name.value": "*kumar*"
}
}

这不是:
"query": {
"wildcard": {
"meta._billing_full_name.value": "*manish k*"
}
}

顺便说一下,我们正在使用AWS ElasticSearch Service作为服务提供商。他们使用的是ElasticSearch的严重过时版本(据我所知为1.5.3),我不确定这是否可能是问题的原因之一。

谢谢

最佳答案

根据您显示的映射,value似乎是multifield。这意味着它已被索引为analyzednot_analyzed字符串。

对于它的not_analyzed版本,请使用以下查询:

"query": {
"wildcard": {
"meta._billing_full_name.value.raw": "*manish k*"
}
}

现在应该可以工作了。

关于php - AWS中ElasticSearch通配符查询和空格的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37978250/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com