3

私は、2つの値の合計を取り、違いを見つけることに関して、Cypherと苦労してきました。ノードの送信合計と受信合計を見つける次の2つのクエリがあります。

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の違いを理解できるように、これら2つの別々のクエリをどのように組み合わせるのですか?私は次のように複数の開始点を試しました:

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はnullです!私には、これは非常に単純なユースケースのように見えます-一体何が間違っているのでしょうか?

4

1 に答える 1

5

このように2つのクエリをスマッシュするだけでは、2つのクエリを組み合わせることができません。:)

これを解決するには、WITHを使用して、クエリを次のように2つの部分に分割することをお勧めします。

START addr = node(5)
MATCH addr <- [:owns] - owner - [to:transfers] -> receiver
WITH addr, SUM(to.value) AS Total_Sent

MATCH addr <- [:owns] - owner <- [from:transfers] - sender
WITH SUM(from.value) AS Total_Received, Total_Sent

RETURN Total_Received, Total_Sent, Total_Received - Total_Sent as Total_Balance

HTH、

アンドレ

于 2012-09-04T19:03:01.663 に答える