【发布时间】:2021-01-04 13:21:50
【问题描述】:
我们使用的是 neo4j 版本 4.1.1,
我们有一个表示对象结构的图。
我们支持使用节点进行翻译,对象和翻译节点之间的联系是对象名称和描述。
例如:
(n:object)-[r:Translation]-(:ru)
表示关系 r 是俄语中对象 n 的名称和描述。
为了按名称和描述进行搜索,我们实现了一个全文索引,如下所示:
CALL db.index.fulltext.createRelationshipIndex("TranslationRelationshipIndex",["Translation"],["Name","Description"], { eventually_consistent: "true" })
我们还支持搜索项目,以便我们使用索引进行查询,我们有类似“UFO41.SI01V03”的名称:
CALL db.index.fulltext.queryRelationships('TranslationRelationshipIndex', '*FO41.SI0*') YIELD relationship, score
但对于如上所示的名称([0-9.*]),不返回任何结果
而结果返回的名称为“ab.or”
有没有人知道如何使它工作?我已经尝试了所有可用的 46 种分析仪。
我知道我们可以使用match()-[r]-() where r.Name contains "<string>" 解决它
但对于这个问题,我们更喜欢使用更有效的索引解决方案。
保持安全! 并提前致谢。
p.s 如果需要,我可以提供几行来在本地重新创建它。
【问题讨论】:
标签: neo4j cypher fulltext-index