如何解决使用 ArangoSearch LIKE 搜索带空格的字符串
我在一个集合上创建了一个 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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。