- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
使用 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/
我已经在 OSX 上安装了 Docker 并下载了 neo 镜像。当我运行它时(使用图像主页中的 args),一切似乎都正常,但日志的最后几行表明如下: 00:20:39.662 [main] INF
我的正则表达式在 neos 项目中不能正常工作。DD/MM/YYYY 的正则表达式(仅限 19XX-20XX) var date_regex = /^(0[1-9]|1\d|2\d|3[01])\/(
Neo 4j可以与HDFS / Hadoop集成吗?在处理涉及许多关系且每秒具有大量事务的大型数据集时,通常使用Hadoop来提高Neo 4j的处理能力。 最佳答案 这是一个非常广泛的问题。也许考虑提
我尝试在 NEO 环境中使用 TenantAccessor。TenantAccessor.getCurrentTenant().getTenantId() 生成的 TenantId 作为 GUID 返
我下载了Neoclipse Source并下载了 Neo4J source 。但是 Neo4J 源文件中找不到 Neoclipse 源文件引用的某些类。它们已被弃用吗?我可以获得 Neoclipse
进程文件: neo or neo.exe 进程名称: Price Patrol 进程类别:存在安全风险的进程 英文描述: neo.exe is the execuatble for Pric
load csv with headers from 'file:///C:/Users/user/Desktop/Neo4J' as row Create (:State_Code {state_c
如何在 SAPUI5 应用程序的运行时为 neo-app.json 文件的 routes 部分定义新条目?例如在 Component.js 内部。 例如,我想将以下条目添加到文件中,或者将一些代码添加
我最近将一台计算机变成了 Ubuntu 服务器。我已经按照下面的文章 http://neos.readthedocs.io/en/stable/GettingStarted/Installation.
我正在尝试了解如何使用 NEOS Server for SCIP .我已经阅读了有关 CPLEX LP file format 的教程.但我仍然得不到任何结果。 让我们以该教程中提供的示例为例: Ma
关于这一年Bubble Cup (完)有问题NEO (我无法解决),它要求 给定一个包含 n 个整数元素的数组。我们把它分成几个部分(可能是1个),每个部分都是一个连续的元素。这种情况下的 NEO 值
我的 Rails 应用程序必须使用 Neo4j。所以我开始安装 neo4j 服务器。我按照步骤安装 here在 Linux 上。 但是当我运行的时候 ./bin/neo4j console 它给了 E
我刚从 windows 10 切换到 arch linux我想使用 (Neo)Vim 作为我的代码编辑器我已经完成了自动编译和模糊查找器但我不知道如何在 (Neo)Vim 中调试 任何帮助! 最佳答案
我想问一下,如何使用Spring boot找到Dijkstra。 我目前使用 spring-boot-starter-data-neo4j 库将 Neo4j 与我的 java 类映射。 我现在想使用
我正在尝试创建一个可以从 U2F token (例如 Java 语言的 Yubikey Neo)检索公钥和私钥的应用程序。我尝试在控制台中使用简单的扫描仪从 Yubikey Neo 获取任何内容,但它
我想用摩托罗拉68000汇编器写一个程序,目标平台是Neo Geo(九十年代的游戏机);这个问题很严重,我有一个我想实现的特定项目并且我有编程经验(虽然我现在主要是 Perl/R 编程,但我以前只接触
我使用自定义 Web 服务作为 neo4j 的非托管扩展。 这是 Neo4j 提供的详细信息,我已遵循该详细信息并创建了自己的非托管扩展。 http://neo4j.com/docs/stable/s
Typo3 Neos 是否原生支持元素的响应行为?例如像 css 网格类(col-sm-?? 或 col-md-??)这样的 Bootstrap ,或者我可以使用 Neos 通过 hidden-xs
我是为嵌入式板构建自定义 Linux 操作系统的新手 - 所以请忽略我的无知。 我有一个名为 NanoPi NEO 的开发板,它具有定制的 Debian Linux。现在开发板附带一个 .img 文件
我正在尝试使用脚本在 NEO4j db 中导入 csv 文件: LOAD CSV FROM "file:///dataframe6.txt" AS line RETURN count(*) 但我收到以
我是一名优秀的程序员,十分优秀!