gpt4 book ai didi

python - py2neo:各种命令的性能和返回值

转载 作者:太空宇宙 更新时间:2023-11-03 18:48:29 24 4
gpt4 key购买 nike

使用 py2neo (1.5.1) 和 neo4j (1.9.2),我想知道不同命令的性能(图中大约有 80k 关系):

所以首先我得到所有关系(~80k),这显然需要一些时间。

graph_db = neo4j.GraphDatabaseService("http://localhost:7474/db/data/")
rels = graph_db.match()

但是,为什么需要花费大量时间(约 1-2 分钟)来循环关系并打印它们(或存储在某个变量中)? rels是一个关系列表,但是每个关系包含什么?

for relation in rels:
print relation.start_node
print relation.type
print relation.end_node
print relation.get_properties()

删除行 print relation.get_properties() 时循环的执行时间变得更好(约 10 秒)。所以我假设每个 relation.get_properties()对数据库执行查询?听起来很有道理。

但是,对我来说奇怪的是:为什么下面的代码要快得多,尽管 print relation包含我需要的所有信息?

for relation in rels:
print relation #example output: (244358)-[:KNOWS {"since":2011,"reason":"unknown"}]->(244359)
print relation.start_node
print relation.type
print relation.end_node

因此它实际上打印了我需要的所有信息,并且执行速度要快得多,尽管这就是为什么我无法提取关系的属性并将其存储在变量中的原因。

for relation in rels:
print relation #example output: (244358)-[:KNOWS {"since":2011,"reason":"unknown"}]->(244359)
print relation.start_node
print relation.type
print relation.end_node
#print relation["since"] #would slow down the execution significantly, why??

那么关系中存储了哪些信息呢?如何在不使用 get_properties() 的情况下提取所有属性。这和缓存有关系吗?我不明白,这让我发疯......我已经在期待你的答案了,奈杰尔;-)

注意:我知道我可以通过使用批处理来优化它,但这并不是现在真正的问题。

编辑:是否 print relation["since"]还会导致每次迭代的查询吗?

编辑2:当我们谈论性能时,还有一件事:比较以下密码查询,我注意到第一个查询比第二个查询慢得多,为什么? (在冷图上执行,因此没有缓存影响)

查询1:START n=节点(*) RETURN n

查询2: START n=node(*) RETURN n.name, n.age

最佳答案

关系对象存储该关系的不可变部分,这些部分在 REST 响应中返回。它们是起始节点、结束节点和类型。属性是可变的,并且调用 get_properties确实(如您所建议的)对服务器进行单独的调用。

<小时/>

旁注:如果您启用日志记录...

import logging
logging.basicConfig(level=logging.DEBUG)

...您应该能够看到来回的流量。

<小时/>

但是,您可以使用一个小技巧来获取属性的快照,而无需单独调用。 __metadata__任何资源的属性都包含从服务器获取的最新已知详细信息,因此以下内容应返回属性:

props = my_rel.__metadata__["data"]

随着 py2neo 1.6(即将发布!),match方法略有演变。它不是在返回给您之前获取所有内容,而是返回一个生成器并且可以迭代。所以代码如...

for rel in graph_db.match("KNOWS"):
print rel.start_node["name"] + " knows " + rel.end_node["name"]

...将更快地执行,而不是等待收到完整响应。

编辑答案:是的。

编辑 2 答案:这是 Neo 人的问题 :-P

关于python - py2neo:各种命令的性能和返回值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18926102/

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