Я боролся с Сайфером, пытаясь вычислить СУММУ двух значений и найти разницу. У меня есть эти два запроса, которые находят общее количество отправленных и полученных узлов:
START addr = node(5)
MATCH addr <- [:owns] - owner - [to:transfers] -> receiver
RETURN SUM(to.value) AS Total_Sent
START addr = node(5)
MATCH addr <- [:owns] - owner <- [from:transfers] - sender
RETURN SUM(from.value) AS Total_Received
В основном мой вопрос: как мне объединить эти два отдельных запроса, чтобы я мог понять разницу между Total_Sent и Total_Received? Я пробовал несколько начальных точек, например:
START sendAddr = node(5), receivedAddr = node(5)
MATCH sendAddr <- [:owns] - sendOwner - [to:transfers] -> receiver, receivedAddr <- [:owns] - receiveOwner <- [from:transfers] - sender
RETURN SUM(to.value) AS Total_Sent, SUM(from.value) AS Total_Received, SUM(to.value) - SUM(from.value) AS Balance
Но Total_Received равен нулю! Для меня это выглядит довольно простым вариантом использования — что, черт возьми, я делаю неправильно?