- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
您好,我在尝试创建/合并节点和关系时收到以下错误。它并不总是发生,但偶尔会发生。
CypherError: An unexpected failure occurred, see details in the database logs, reference number eaf50bff-deca-4055-9450-6a76c31534e4.
这是回溯:
---------------------------------------------------------------------------
CypherError Traceback (most recent call last)
<ipython-input-21-9700f3a5d3fa> in <module>()
7 tx.success = True
8 #tx.close()
----> 9 session.close()
/databricks/python/local/lib/python2.7/site-packages/neo4j/v1/session.pyc in close(self)
522 """
523 if self.last_result:
--> 524 self.last_result.buffer()
525 if self.transaction:
526 self.transaction.close()
/databricks/python/local/lib/python2.7/site-packages/neo4j/v1/session.pyc in buffer(self)
246 if self.connection and not self.connection.closed:
247 while not self._consumed:
--> 248 self.connection.fetch()
249 self.connection = None
250
我的创建/合并代码是这样的:
for chunk in chunk_list:
with session.begin_transaction() as tx:
for record in chunk:
tx.run("MERGE (source:UID {userid : {m}, timestamp: {a}})"
"MERGE (target:UID {userid : {n}, timestamp: {a}})"
"MERGE (source)-[:HasConnection]-(target)", {"m": record.source, "n": record.target, "a": record.unix_timestamp_s})
tx.success = True
#tx.close()
session.close()
chunk_list 是包含多个记录列表的列表。 chunk_list 中的每个列表都有多行(大约 10000),每行包含三列:源、目标和时间戳。
对于 chunk_list 中的每个列表,我们打开一个 session ,然后执行合并操作,然后关闭 session 。
当图超过 1000 万个节点时,问题就会开始发生。假设第 1 天,chunk_list 有 400 万行,它会工作得很好,对于第 2 天,如果 chunk_list 有 400 万行,它也会工作得很好。但是,如果在第 3 天,Neo4j 图中有 300 万行,并且节点总数超过 1000 万,那么问题就开始发生。
最佳答案
执行时间如此长的原因之一是您的查询没有执行您认为它正在执行的操作。
执行 MERGE 就像尝试首先执行 MATCH,如果没有找到匹配项,则执行 CREATE。
在您的评论中,您说时间戳应该在 MERGE 操作期间更改,因此您真正想要做的是更新具有相同用户 ID 的节点的属性,但这不是您的 MERGE 所做的。
您的 MERGE 首先尝试将 :UID 节点与给定的用户 ID 和时间戳进行匹配,但是您的图中不会有这样的节点,因为时间戳是新的...将会有一个 :UID 节点相同的用户 ID,但具有不同的时间戳,因此不会找到匹配项,并且将使用与现有节点相同的用户 ID 和新时间戳创建一个全新的 :UID 节点。
因此,您的 MERGE 始终会创建新节点,并且永远不会匹配现有节点。 MERGE 本身永远不会更新属性值,因此永远不要尝试以这种方式使用它。
要执行匹配和更新,您需要仅根据现有节点上匹配的最小唯一属性进行 MERGE,然后使用 SET 更新属性,如下所示:
for chunk in chunk_list:
with session.begin_transaction() as tx:
for record in chunk:
tx.run("MERGE (source:UID {userid : {m}})"
"SET source.timestamp = {a}"
"MERGE (target:UID {userid : {n}})"
"SET target.timestamp = {a}"
"MERGE (source)-[:HasConnection]-(target)", {"m": record.source, "n": record.target, "a": record.unix_timestamp_s})
tx.success = True
#tx.close()
session.close()
此外,为了确保 MERGE 快速,您需要对 :UID(userid) 有一个索引或唯一约束,否则 Neo4j 将必须进行标签扫描来查找节点,这太慢了图表的大小。
编辑
我还没有将 Python 与 Neo4j 一起使用,但我不确定这种循环是处理多个记录的正确方法,因为它看起来会运行给定 Cypher 段的大量副本。每行 5 行 Cypher 似乎很极端...理想情况下,您应该使用 Cypher 代码同时对所有行(或至少每个 block 的行)进行操作,并且您的输入可以轻松转换为行以供执行。
更好的方法可能是使用循环生成对象列表(具有“m”和“n”属性),并将该列表和单个时间戳作为参数提交给查询。
然后,您可以将 Cypher 中的列表展开回行,并使用它。因此,如果“row”是您的对象列表参数,而“a”仍然是您的 unix 时间戳参数,则 Cypher 段将如下所示:
UNWIND {row} as line
MERGE (source:UID {userid : line.m})
SET source.timestamp = {a}
MERGE (target:UID {userid : line.n})
SET target.timestamp = {a}
MERGE (source)-[:HasConnection]-(target)
关于python - 使用 Neo4j-Python 连接器创建/合并图形期间出现 CypherError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41454933/
我一直在为此而苦苦挣扎。我想插入一个图像,并将其“靠近”讨论该图像的文本,但是该页面上的文本将围绕图像环绕/流动。 我已将图像转换为eps格式。最初,我尝试使用图形环境(\begin {figure}
我在用户界面中创建了管理控制台,管理员可以在其中执行所有操作,例如创建、删除用户、向用户分配应用程序以及从用户界面删除用户的应用程序访问权限 我厌倦了使用 Microsoft 图形 API 和 Azu
我在用户界面中创建了管理控制台,管理员可以在其中执行所有操作,例如创建、删除用户、向用户分配应用程序以及从用户界面删除用户的应用程序访问权限 我厌倦了使用 Microsoft 图形 API 和 Azu
我想为计算机图形学类(class)做一个有趣的项目。我知道那里有很多文献(即 SIGGRAPH session 论文)。我对计算机图形学(即图像处理、3D 建模、渲染、动画)兴趣广泛。但是,我只学了
我试图在 MaterializeCSS 网站上创建一些类似于这个的图形,但我不知道它来自哪里,我查看了整个 MaterializeCSS 网站,它不是框架的一部分,我找不到在代码中他们使用的是什么 我
我有一个包含 1 到 6 之间的各种数字的 TextView ,每个数字在每一行上代表一次,例如 123456 213456 214356 ...... 我希望能够绘制一条蓝线来跟随单个数值在列表中向
我目前在 Windows 7 上使用 Netbeans 和 Cygwin,我希望用 C 语言编写一个简单的 2D 游戏。 我设法找到的大多数教程都使用 Turbo C 提供的 graphics.h,C
亲爱的,我正在尝试将 kaggle 教程代码应用于 Iris 数据集。 不幸的是,当我执行图表的代码时,我只能看到这个输出而看不到任何图表: matplotlib.axes._subplots.Axe
我需要加快我正在处理的一些粒子系统的视觉效果。令人眼前一亮的是添加混合、积累以及粒子上的轨迹和发光。目前我正在手动渲染到浮点图像缓冲区,在最后一分钟转换为无符号字符,然后上传到 OpenGL 纹理。为
在研究跨网络的最短路径算法时,我想生成网络图片。我想代表节点(圆圈)、链接(线)、遍历链接的成本(链接线中间的数字)和链接的容量(链接线上它代表的节点旁边的数字)在这张图中。是否有任何库/软件可以帮助
尽管我已将应用程序从库添加到 Azure AD,但我无法看到何时尝试提取数据。但我可以看到添加的自定义应用程序。就像我添加了 7 个应用程序一样; 2 个来自图库(Google 文档、一个驱动器)和
因此,我正在构建一个系统,该系统具有“人员”,“银行帐户”和“银行帐户交易”。 我需要能够回答以下问题: “将所有与1/2/3度有联系的人归还给特定的人”, “返回年龄在40岁以上的所有人” “从德国
我在 JFrame 构造函数中有以下简单代码 super(name); setBounds(0,0,1100,750); setLayout(null); setVis
(这是java)我有一个椭圆形,代表一个单位。我希望椭圆形的颜色代表单位的健康状况。因此,一个完全健康的单位将是全绿色的。随着单位生命值的降低,椭圆形开始从底部填充红色。因此,在 50% 生命值下,椭
我目前正在开发一个学校项目。我们必须制作一个Applet,我选择了JApplet。由于某种原因,我用来显示特定字符串的面板将不会显示。这里可能有什么问题?请指出我正确的方向。另外,我看了一些教程,
我正在尝试创建一个 Simon game 。我正在编写游戏程序,但遇到了问题。我希望程序从队列中读取游戏中之前存在的所有值,并以正确的顺序将它们的颜色变为闪烁(我选择将它们变为灰色,然后在第二秒后恢复
我正在尝试创建一个框架,该框架在同一框架的顶部有一个图形面板(通过布局),在其下方有一个按钮/标签面板。到目前为止,我似乎已经能够将它们放在同一个框架上,但与按钮/标签面板相比,图形面板非常小....
我用 Java 编写了一个解决数独问题的代码,并使用 Java Applet 来设计它。现在,我尝试使用 Java Swing 使其看起来更好,并添加一些功能,例如“保存”数独板等。不幸的是,我对 J
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我现在尝试了 8 个多小时来解决这个问题,但无法弄清楚,请帮助找出我的代码有什么问题。 int main() { int gd = DETECT, gm; float ANGLE =
我是一名优秀的程序员,十分优秀!