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

时间:2016-06-22 21:07:11

标签: php wordpress amazon-web-services elasticsearch

我们最近整合了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),我不确定这是否是问题的原因之一。

由于

1 个答案:

答案 0 :(得分:3)

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

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

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

现在应该可以了。