Head's Up! These forums are read-only. All users and content have migrated. Please join us at community.neo4j.com.
11-21-2022 10:19 AM
I need to use an aggregation function like `min()` , but instead of returning the result of the function, I need the full node as I then need to use one of the node's property in a subsequent MATCH statement. I've tried using the following query:
````
MATCH (n) WHERE n.uid IN $uids
WITH n as nodes, apoc.agg.minItems(n, n.level).items as highestNode WITH nodes, apoc.agg.first(highestNode).tree_id AS highestTreeId
MATCH (nodes)-[:TRANSLATES_TO]-(a) WHERE a.tree_id = highestTreeId return nodes, a
`
This uses the `minItems()` apoc function but the problem is it does not return a list and rather a separate map for each node processed. The result of the minItems function looks like this, for 3 nodes processed. I then need the first map in this function to be used in the next match statement:
I've thought about using reduce or list comprehension but not sure how that would work. What's the common approach to this problem?
Solved! Go to Solution.
11-21-2022 01:30 PM
You got a map per node because the apoc.agg.minItem is an aggregate function and you have 'with n, apoc.agg.minItem()', so its grouping the rows with the same value of 'n' and passing them to the aggregate function. This result in one result per node 'n'.
I am not sure I understand your requirement from the code, but I took a stab at it using list comprehension instead of apoc functions. You can try this. Let me know if something is wrong and we can try to fix it.
match(n)
with collect({node:n, level:n.level}) as nodes, min(n.level) as min
with nodes, [x in nodes where x.level = min][0].node as minNode
unwind nodes as node
with node.node as n, minNode
match (n)-[:TRANSLATES_TO]-(minNode)
return n, minNode
11-21-2022 01:30 PM
You got a map per node because the apoc.agg.minItem is an aggregate function and you have 'with n, apoc.agg.minItem()', so its grouping the rows with the same value of 'n' and passing them to the aggregate function. This result in one result per node 'n'.
I am not sure I understand your requirement from the code, but I took a stab at it using list comprehension instead of apoc functions. You can try this. Let me know if something is wrong and we can try to fix it.
match(n)
with collect({node:n, level:n.level}) as nodes, min(n.level) as min
with nodes, [x in nodes where x.level = min][0].node as minNode
unwind nodes as node
with node.node as n, minNode
match (n)-[:TRANSLATES_TO]-(minNode)
return n, minNode
11-22-2022 01:28 AM
Thanks for the explanation. This was the query I used in the end:
`
All the sessions of the conference are now available online