我有一个长的Cypher查询(新的Neo4J 2.0版本),它使用合并命令创建多个节点和连接。
问题是:你认为我最好把它分割成不同的部分,并将其作为事务(为了健壮性)提交,还是应该保留长的单个部分(为了速度)?
以下是查询:
MATCH (u:User {name: "User"}) MERGE (tag1:Hashtag {name:"tag1"}) MERGE (tag2:Hashtag
{name:"tag2"}) MERGE (tag3:Hashtag {name:"tag3"}) MERGE (tag4:Hashtag {name:"tag4"})
MERGE tag1-[:BY]->u MERGE tag2-[:BY]->u MERGE tag3-[:BY]->u MERGE tag4-[:BY]->u;(我故意缩短了请求,假设有大约50个标记(节点),甚至更多的边(例如))
发布于 2014-02-10 12:05:24
只要查询语句不是数百行,并且所创建的数据不超过50k元素,我就坚持一个查询。
但是你应该用参数代替。
我还将用foreach和参数重写您的查询。
MATCH (u:User {name: {userName})
FOREACH (tagName in {tags} |
MERGE (tag:Hashtag {name:tagName})
MERGE (tag)-[:BY]->(u)
)params:
{userName:"User", tags: ["tag1",...,"tagN"]}https://stackoverflow.com/questions/21675747
复制相似问题