问题描述
我在一个集合上创建了一个 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版
解决方法
问题是因为您使用的是 text_en
,它将字符串分解为单个单词由于所有空格都被视为中断字符,因此没有一个术语(存储在 aragnosearch 索引中的单词)包含空格.
如果您不需要标记化,请考虑使用 identity
分析器按原样索引单词(即不进行大小写转换、去除重音等),或查看 norm
分析器。
https://www.arangodb.com/docs/stable/arangosearch-analyzers.html#analyzer-types