我们最近整合了ElasticPress for WooCommerce,并对其代码进行了一些改进(通过它的过滤器),但遇到了一些似乎是ElasticSearch API限制的问题。我们在搜索订单时对发送到弹性搜索引擎的查询进行了修改,以便搜索项作为部分搜索(非常类似于SQL中的LIKE语句)。
它工作正常,除非查询中有特殊符号,如空格或@符号。我已经读到这可以通过逃避特殊字符来避免,但我也没有运气。
我正在使用通配符查询,我尝试使用其转义版本替换空格,甚至是?令牌(应匹配任何单个字符)。也没有运气。
此查询有效:
"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),我不确定这是否是问题的原因之一。
由于
答案 0 :(得分:3)
根据您显示的映射value
似乎是multifield。这意味着它已被编入索引为analyzed
和not_analyzed
字符串。
对于not_analyzed
版本,请使用以下查询:
"query": {
"wildcard": {
"meta._billing_full_name.value.raw": "*manish k*"
}
}
现在应该可以了。