我是第一次尝试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'})
现在我想在节点之间添加关系。但是,我不想想要清除使用上述脚本创建的现有数据库,添加语句并再次运行它。我想将关系添加到现有节点。 Google帮我找到了这个:
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属性的节点,而不是使用标签来检查节点的类型是否正确。
如何使用标签来做同样的事情?
最佳答案
在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及更高版本。