0

我在一个集合上创建了一个 ArangoSearch 视图,并使用带有 LIKE 的通配符的 SEARCH 关键字来搜索带有空格的字段,类似于 MySQL 的方式。我遇到的问题是,即使肯定存在带有《星球大战》标题的记录,我仍然会得到一个空集。

请注意,搜索“%star%”有效并返回结果...只要我添加空格并搜索“%star wars%”,查询就会返回空集。

这是查询

FOR d IN imdb_norm
SEARCH ANALYZER(d.name LIKE "%Star Wars%", "text_en")
RETURN d.name

这是结构,运行arango 3.7.2版本

在此处输入图像描述

4

1 回答 1

0

问题是由于您使用的是text_en,它将字符串分解为单个单词 由于所有空格都被视为中断字符,因此没有一个术语(存储在 aragnosearch 索引中的单词)包含空格。如果您不需要标记化,请考虑使用分析器按原样索引一个单词(即不进行大小写转换、重音删除等)identity,或者norm改用分析器。

https://www.arangodb.com/docs/stable/arangosearch-analyzers.html#analyzer-types

于 2021-02-11T21:15:40.280 回答