使用 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版

enter image description here

解决方法

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

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...