Head's Up! These forums are read-only. All users and content have migrated. Please join us at community.neo4j.com.
05-21-2020 02:09 AM
Hi to everyone!
I ran two queries which - I believe, however I might as well be completely wrong - return the same results:
<>MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address {AddressID: 'xxxxxxxxxxxxxxxxx'})
RETURN distinct(src.AddressID) as first_order_txs
LIMIT 5;</>
<>MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address) WHERE dst.AddressID IN
['xxxxxxxxxxxxxxxxx']
RETURN distinct(src.AddressID) as first_order_txs
LIMIT 5;</>
The result in both cases is a table with 5 entries; the entries are not the same. My expectation was that they would be the same.
Thanks!
Andreas
Solved! Go to Solution.
05-21-2020 05:39 AM
Hello @and.manousakis,
First of all, in case you have only one AddressID
, use your first request:
MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address {AddressID: 'xxxxxxxxxxxxxxxxx'})
RETURN distinct(src.AddressID) AS first_order_txs
LIMIT 5
But if you have multiple AddressID
, use your second request:
MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address)
WHERE dst.AddressID IN ['xxxxxxxxxxxxxxxxx']
RETURN distinct(src.AddressID) AS first_order_txs
LIMIT 5
Now if you want to get the same results, you should try to add an ORDER BY clause before the LIMIT, for example:
MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address {AddressID: 'xxxxxxxxxxxxxxxxx'})
RETURN distinct(src.AddressID) AS first_order_txs
ORDER BY first_order_txs
LIMIT 5
Regards,
Cobra
05-21-2020 05:39 AM
Hello @and.manousakis,
First of all, in case you have only one AddressID
, use your first request:
MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address {AddressID: 'xxxxxxxxxxxxxxxxx'})
RETURN distinct(src.AddressID) AS first_order_txs
LIMIT 5
But if you have multiple AddressID
, use your second request:
MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address)
WHERE dst.AddressID IN ['xxxxxxxxxxxxxxxxx']
RETURN distinct(src.AddressID) AS first_order_txs
LIMIT 5
Now if you want to get the same results, you should try to add an ORDER BY clause before the LIMIT, for example:
MATCH (src:Address)-[:REDEEMED]->(ip:IncomingPayment)-[:INCOMING_PAYMENT]->(tx:Transaction)-[:SENT_COINS]->(op:OutgoingPayment)-[:WAS_SENT_TO]->(dst:Address {AddressID: 'xxxxxxxxxxxxxxxxx'})
RETURN distinct(src.AddressID) AS first_order_txs
ORDER BY first_order_txs
LIMIT 5
Regards,
Cobra
05-23-2020 01:21 AM
Hi @Cobra @cristiscu, thank you for the replies! I used ORDER BY src.AddressID DESC LIMIT 5; and the results were indeed the same.
Best
Andreas
05-21-2020 10:50 PM
Interesting finding, Andreas. I also expected the Neo4j internal parser to translate exact matches into similar queries and return the same result.
If, as Cobra said, only their result order is different, then it behaves just like in SQL: the results are indeed guaranteed to be the same, but not necessarily in the same order. Unless you use ORDER BY.
Cheers,
-C
All the sessions of the conference are now available online