我正在使用 Elastic 的 PHP 实现来使用这样的 Completion Suggester:
$params_organisations = [
'index' => $this->organisation_index,
'body' => [
"suggest" => [
"suggestions" => [
'prefix' => $request->q,
"completion" => [
"field" => "suggest1",
"fuzzy" => ["fuzziness" => 0],
"skip_duplicates" => "false",
"size" => 7
]
]
]
]
];
但是,响应还包含其他索引:
suggest: {suggestions: Array(1)}
timed_out: false
took: 8
_shards:
failed: 3
failures: Array(3)
0:
index: ".kibana_1"
node: "xxxxxxxxx"
reason: {type: "illegal_argument_exception", reason: "no mapping found for field [suggest1]"}
我担心这可能会影响性能,因为其他一些索引也包含一个suggest1
, 字段并且它们被搜索并返回结果。我没有更改名称,有时我想以类似的方式处理建议字段,但是跨索引具有相同的建议类型字段名称是否有问题?
或者有没有办法更明确地定义索引?我也尝试将索引名称附加到端点,但结果相同。我在 PHP 实现中找到了一个明确的建议端点,但它似乎已被弃用?任何帮助深表感谢!