- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
鉴于我们有以下 Neo4j 模式(简化但显示了重点)。有两种类型的节点NODE
和 VERSION
. VERSION
s 连接到 NODE
s 通过 VERSION_OF
关系。 VERSION
节点确实有两个属性 from
和 until
表示有效时间跨度 - 一个或两个都可以是 NULL
(在 Neo4j 术语中不存在)表示无限。 NODE
s 可以通过 HAS_CHILD
连接关系。同样,这些关系有两个属性 from
和 until
表示有效时间跨度 - 一个或两个都可以是 NULL
(在 Neo4j 术语中不存在)表示无限。
编辑 : 有效期为VERSION
节点和 HAS_CHILD
关系是独立的(即使该示例巧合地显示它们是对齐的)。
该示例显示了两个 NODE
s 一个 和 乙 . 一个 有两个 VERSION
s AV1 直到 6/30/17 和 AV2 从 7/1/17 开始,同时 乙 只有一个版本 BV1 那是无限的。 乙 已连接到 一个 通过 HAS_CHILD
关系直到 6/30/17。
现在的挑战是查询所有不是 的节点的图。 child (即根节点)在某个特定时刻。给定上面的例子,查询应该只返回 乙 如果查询日期是例如6/1/17,但它应该返回 乙 和 一个 如果查询日期是例如2017 年 8 月 1 日(因为 A 不再是 B 的子代 | 17 年 7 月 1 日)。
今天的当前查询与那个大致相似:
MATCH (n1:NODE)
OPTIONAL MATCH (n1)<-[c]-(n2:NODE), (n2)<-[:VERSION_OF]-(nv2:ITEM_VERSION)
WHERE (c.from <= {date} <= c.until)
AND (nv2.from <= {date} <= nv2.until)
WITH n1 WHERE c IS NULL
MATCH (n1)<-[:VERSION_OF]-(nv1:ITEM_VERSION)
WHERE nv1.from <= {date} <= nv1.until
RETURN n1, nv1
ORDER BY toLower(nv1.title) ASC
SKIP 0 LIMIT 15
NODE
s(大约是
VERSION
s 数量的两倍)(真实)查询在运行在 Mac OS X 上的小型 docker 容器上大约需要 500-700 毫秒),这是可以接受的。但是有 1.5M
NODE
s(大约是
VERSION
s 的两倍),(真实)查询在裸机服务器(只运行 Neo4j)上需要 1 分钟多一点的时间。这实在是不能接受。
NODE
的版本控制? s(我怀疑是这里的性能问题)还是关系的有效性?我知道关系属性不能被索引,所以可能有更好的模式来处理这些关系的有效性。
ITEM_VERSION
第一个节点 MATCH
:ITEM_VERSION
nv2
将结果集过滤为 ITEM
没有其他连接的节点 ITEM
给定日期的节点。这意味着必须不存在对给定日期有效的关系,或者连接的项目不得具有 ITEM_VERSION
这对给定的日期有效。我试图说明这一点:// date 6/1/17
// n1 returned because relationship not valid
(nv1 ...)->(n1)-[X_HAS_CHILD ...6/30/17]->(n2)<-(nv2 ...)
// n1 not returned because relationship and connected item n2 valid
(nv1 ...)->(n1)-[X_HAS_CHILD ...]->(n2)<-(nv2 ...)
// n1 returned because connected item n2 not valid even though relationship is valid
(nv1 ...)->(n1)-[X_HAS_CHILD ...]->(n2)<-(nv2 ...6/30/17)
ITEM
节点通过自定义关系类型连接。由于我们不能在一个关系上有多个类型/标签,这些关系的唯一共同特征是它们都以 X_
开头。 .这已被排除在此处的简化示例之外。将使用谓词搜索 type(r) STARTS WITH 'X_'
这里有帮助吗? 最佳答案
您使用的是什么 Neo4j 版本。
在您的示例日期,您的 150 万个节点中有多少百分比会被发现为根,如果您没有限制,返回多少数据?也许问题不在于比赛,而在于最后的排序?
我不确定您为什么在第一部分中有 VERSION 节点,至少您没有将它们描述为与确定根节点相关。
你没有使用关系类型。
MATCH (n1:NODE) // matches 1.5M nodes
// has to do 1.5M * degree optional matches
OPTIONAL MATCH (n1)<-[c:HAS_CHILD]-(n2) WHERE (c.from <= {date} <= c.until)
WITH n1 WHERE c IS NULL
// how many root nodes are left?
// # root nodes * version degree (1..2)
MATCH (n1)<-[:VERSION_OF]-(nv1:ITEM_VERSION)
WHERE nv1.from <= {date} <= nv1.until
// has to sort all those
WITH n1, nv1, toLower(nv1.title) as title
RETURN n1, nv1
ORDER BY title ASC
SKIP 0 LIMIT 15
关于graph - Neo4j Cypher 查询以查找未连接太慢的节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41300518/
我用 cudaMemcpy()一次将 1GB 的数据精确复制到设备。这需要 5.9 秒。反之则需要 5.1 秒。这是正常的吗?函数本身在复制之前有这么多开销吗? 理论上,PCIe 总线的吞吐量至少应为
我正在尝试读取图像的大小并在其高度大于 150 时调整其边距。但是在运行这段代码时,我总是在控制台中得到一个“0”: var coverImg; coverImg =
我正在开发一个 iPhone 应用程序,其中包含一些标准的“相机”功能。保存到相机胶卷真的太慢了,在iPhone 4上大约需要四秒钟。有什么办法可以提高速度吗? 如果您查看默认的 iPhone 相
我创建了一个将图像转换为灰度的类。但它的工作速度太慢了。有没有办法让它运行得更快? 这是我的类(class): @implementation PixelProcessing SYNTHESIZE_S
我使用以下代码,结果是正确的,但 gethostbyaddr 需要大约 30 秒。 function IPAddrToName(IPAddr: string): string; var So
我有以下案例, public class Test { private static final int MAX_NUMBER = 10_00_00; public static vo
我已经正确添加了所有必需的 JARS: Ucanaccess 3.0.4 commons-lang-2.6 commons-logging-1.1.1 hsqldbd jackcess-2.1.3 我
我为特定功能构建了一个多处理密码破解程序(使用单词列表),与使用单个进程相比,它减少了一半的时间。 最初的问题是,它会向您显示破解的密码并终止工作人员,但剩余的工作人员将继续工作,直到他们用完可哈希的
我在我的一个 JSP 中引入了 Sencha 网格。本地 sencha 相当快,但在外部服务器上它太慢了。 我在这里按照部署说明进行操作 http://docs.sencha.com/ext-js/4
我的查询加载时间有很大问题。在这种情况下,我需要 hg_ft_won 列(表:值)中的值,用于 home_team_id 和 away_team_id(表:匹配)。 它确实可以正常工作。加载只需要很长
我现在正在学习不同类型的排序,我发现,从某个点开始,我的快速排序算法根本无法快速工作。 这是我的代码: class QuickSort { // partitioning arr
为什么要模式 [0123]123456|98765 比在 Java 中执行 [0123]123456 然后 98765 慢两倍?所以单独搜索它们比用 OR 执行更快。有人有解释吗? UPD 查看带有结
我有带 Assets 的 Android 应用程序。它们包含 20,000 多个文件,其中大部分是简单的文本或 png 文件,分为不同的文件夹和子文件夹。1 个单个文件的最大大小为 500kb,其中
您好,我在查询中添加了 GROUP_CONCAT 函数,该函数终止了我的查询:/。我的查询是: SELECT u.username,a.user_id,a.id,a.text,a.lang as fr
我正在寻找优化查询的想法。 目前,我有一个 4M 行的表,我只想检索引用的最后 1000 行: SELECT * FROM customers_material_events WHERE refere
我在我的应用程序中使用 NSURLConnection,我在其中扫描条形码,通过 NSURLConnection 发送 XML,Java 服务向我发回 XML。我的问题是,使用 Wifi 时,响应时间
当我运行以下程序时,执行大约需要 7 到 8 分钟。我真的不确定我哪里弄错了,因为这个程序执行起来要花很多时间。 public class Test { public stat
我正在使用 NSFetchResultsController 从数据库中接收项目(有 80.000 个项目)。 这是我的谓词:@"(desc CONTAINS[cd] %@)", [any text]
我在 x_data 中有一个 3x2000 numpy 数组,在 y_data 中有一个 1x2000 numpy 数组,我将其传递给此函数 regress 以给我一条回归线。它工作正常。问题是我正在
我正在做一个项目,我需要改变图像的亮度和对比度,它是亮度而不是亮度。所以我一开始的代码是 for (int y = 0; y (y, x); // read pixel (0,0)
我是一名优秀的程序员,十分优秀!