【问题标题】:neo4j fulltext index search with special charcters带有特殊字符的 neo4j 全文索引搜索
【发布时间】: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


    【解决方案1】:

    分析器可能会以不同于ab.or123 的方式识别诸如ab.or 之类的词,并在第一种情况下将它们视为单个标记,在第二种情况下将它们视为两个标记。

    除了创建您自己的分析器之外,没有任何分析器能真正满足您的需求。

    但是,您可以将查询中的 . 替换为简单的 AND,例如:

    CALL db.index.fulltext.queryNodes('Test', replace("*FO41.SI0*", ".", " AND "))
    

    将返回您正在查看的结果。


    用于创建您自己的分析器的资源:

    https://graphaware.com/neo4j/2019/09/06/custom-fulltext-analyzer.html

    https://neo4j.com/docs/java-reference/current/extending-neo4j/full-text-analyzer-provider/

    【讨论】:

      猜你喜欢
      • 2016-05-30
      • 1970-01-01
      • 1970-01-01
      • 2020-11-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-03-14
      • 1970-01-01
      相关资源
      最近更新 更多