2

我在 neo4j 中有一个正在构建的图形数据库,并且需要能够在索引引用的节点上搜索全部或部分文本。下面是一个示例节点,我可以在其中使用名为 Game 的索引进行搜索:

Node[1]{Type:"Game",Name:"Super Mario Kart",Description:"First Mario Kart Game in the series",Id:"a3b11cd8-b179-4775-a69e-ddcdd7b8369e"}

这是我正在使用的 Cyper 查询:

START game=node:Game('Name:*Super Mario*') RETURN game;

但是,此查询不返回任何内容。如果我像这样修改查询,它会返回,但我希望能够搜索 Name 属性中的所有文本,无论文本中是否有空格:

START game=node:Game('Name:*Super*') RETURN game;

这是我用于查询索引的 C# 代码:

Node<Game> game = client.QueryIndex<Game>("Game", IndexFor.Node, "Name:*" + name + "*").First();

这是游戏实体类:

public class Game
{
    public string Name { get; set; }

    public string Description { get; set; }

}

我是 Cypher 的新手,主要是在寻找与 SQL 的 LIKE 子句等效的内容。一旦我在 Neo4j 的控制台中正确构建并运行了查询,在 Neo4jClient 中开始工作应该是微不足道的。请让我知道您可能有的任何建议。谢谢。

4

1 回答 1

2

事实证明,搜索所有文本就像这样简单:

START game=node:Game('Name: "Mario Kart"') RETURN game;

这根本不需要“*”字符,并返回所有名称为“Mario Kart”的游戏。我希望这可以帮助任何有同样问题的人。

于 2012-12-30T17:05:13.187 回答