我想知道这是如何工作的,以及为什么不返回路径中的节点数。假设我匹配路径p.现在:
WITH p, count(nodes(p)) AS L1 RETURN L1返回1。
当这是明确的,我如何正确地计数路径节点?
发布于 2015-03-19 10:20:41
count()是一个聚合函数。当使用任何聚合函数时,结果行将按RETURN子句中包含的内容进行分组,而不是是一个聚合函数。在这种情况下,结果行将按p分组,返回值将被计数(节点(P))。
nodes(p)返回--节点的数组,因此count(nodes(p))将返回数组的计数,并且总是等于1。
为了返回路径中节点的数量,应该使用size(nodes(p))。
如果您只是对路径的长度感兴趣,而不是特别地对其中包含的节点感兴趣,我将鼓励您使用length(p). 这将返回给定路径的rels长度,而不必操作/访问节点。
https://stackoverflow.com/questions/29141415
复制相似问题