gpt4 book ai didi

neo4j - 在现有节点之间创建关系的更快方法?

转载 作者:行者123 更新时间:2023-12-01 16:18:08 26 4
gpt4 key购买 nike

我正在开发一个应用程序,其中我的 neo4j 数据库中只有“11263”个节点。我正在使用以下密码查询来形成节点之间的关系:

let CreateRelations(fromToList : FromToCount list)=
client.Cypher
.Unwind(fromToList, "fromToList")
.Match("(source)", "(target)")
.Where("source.Id= fromToList.SId and target.Id= fromToList.FId ")
.Merge("(source)-[relation:Fights_With]->(target)")
.OnCreate()
.Set("relation.Count= fromToList.Count,relation.Date= fromToList.Date")
.OnMatch()
.Set("relation.Count= (relation.Count+ fromToList.Count )")
.Set("relation.Date= fromToList.Date")
.ExecuteWithoutResults()

在 neo4j 数据库中形成 1000 个关系需要将近 47 到 50 秒。我是 neo4j 数据库的新手,还有其他有效的方法吗?

最佳答案

最让你慢下来的是你没有使用 index查找您的起始节点。您与 source 的匹配正在对数据库中的所有节点执行扫描,以在展开列表中的每一行中找到可能的匹配项。然后它对 target 做同样的事情。

您需要在您的节点上添加标签,如果它们已经有标签,请在您的查询中使用这些标签。您将需要标签和 id 属性的索引或唯一约束,以便索引将用于查找。

调整查询的最佳方法是在浏览器中尝试它们,并使用 EXPLAIN 确保您正在使用索引查找,如果它仍然很慢,请在查询上使用 PROFILE(它将执行查询)在查询执行时查看生成的行和数据库命中。

关于neo4j - 在现有节点之间创建关系的更快方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48220979/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com