我第一次尝试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属性的节点,而不是使用标签来检查它是否具有正确的节点类型。
如何使用标签进行相同操作?
答案 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)