使用Cypher添加与现有节点的关系

时间:2013-12-08 16:49:58

标签: neo4j cypher

我第一次尝试Neo4j。我正在使用2.0-RC1社区版。

我创建了一些节点:

MERGE (u:User{username:'admin',password:'admin'})
MERGE (r1:Role{name:'ROLE_ADMIN'})
MERGE (r2:Role{name:'ROLE_WEB_USER'})
MERGE (r3:Role{name:'ROLE_REST_USER'})

现在我想添加节点之间的关系。但是,我想要清除使用上面脚本创建的现有数据库,添加语句并再次运行它。我想添加与现有节点的关系。谷歌帮我找到了这个:

START n=node(*), m=node(*)  
where has(n.username) and has(m.name) and n.username = 'admin' 
and m.name = 'ROLE_WEB_USER' 
create (n)-[:HAS_ROLE]->(m)

哪个工作正常(即使我不理解所有语法)。但是,我知道这会找到任何具有username属性的节点和任何具有name属性的节点,而不是使用标签来检查它是否具有正确的节点类型。

如何使用标签进行相同操作?

2 个答案:

答案 0 :(得分:67)

在Neo4j 2.0中,您可以为标签和用于查找的属性创建架构索引:

CREATE INDEX ON :User(username)
CREATE INDEX ON :Role(name)

要创建您可能使用的关系:

MATCH (u:User {username:'admin'}), (r:Role {name:'ROLE_WEB_USER'})
CREATE (u)-[:HAS_ROLE]->(r)

如果可能,MATCH将使用索引。如果没有索引,它将查找带有标签的所有节点,并查看属性是否匹配。

N.B。上面的语法只适用于Neo4j 2.0.0-RC1及以上版本。

答案 1 :(得分:5)

自2020年4月4日起更新:
新的Cypher语法如下。 'CREATE INDEX ON'已被弃用。.

CREATE INDEX FOR (n:Label) ON (n.property)