[英]How can I create nodes and create a one-to-many relationship another newly created node?
UNWIND $likedMovies AS likedMovie
MERGE (lm:LikedMovie {
id: likedMovie.id,
name: likedMovie.name,
})
CREATE p = (:Person $person)-[:LIKES]->(lm)
This doesn't solve my problem as it creates a new Person for every likedMovie
Instead I want the single Person
to be related to all the likedMovie
's这并不能解决我的问题,因为它为每个likedMovie
创建了一个新 Person 相反,我希望单个Person
与所有likedMovie
相关
I also tried this:我也试过这个:
UNWIND $likedMovies AS likedMovie
MERGE (lm:LikedMovie {
id: likedMovie.id,
name: likedMovie.name,
})
CREATE p = (:Person $person)
FOREACH (lm in likedMovie |
MERGE (p)->[:LIKES]-(lm)
)
But, it's giving me an error that p
is a Path and needs to be a Node
但是,它给了我一个错误p
是一个路径并且需要是一个Node
When you assigned p = (:Person), it created a path with nodes in it.当您分配 p = (:Person) 时,它会创建一个包含节点的路径。 But if you assign a variable (p:Person), the variable p is the node itself.但是如果你分配一个变量 (p:Person),变量 p 就是节点本身。 Thus, you can use it to create your relationship with p one-to-many.因此,您可以使用它来创建与 p 一对多的关系。
CREATE (p:Person $person)
UNWIND $likedMovies AS likedMovie
WITH p, likedMovie
MERGE (p)-[:LIKES]->(likedMovie)
This template should do it (although I do not know what is in $person
)这个模板应该可以做到(虽然我不知道$person
中有什么)
CREATE (p:Person {name: $person})
FOREACH(m in $likedMovies |
MERGE (lm:LikedMovie {id: m.id, name: m.name})
MERGE (p)-[:LIKES]->(lm)
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.