簡體   English   中英

Java Neo4j密碼或匹配

[英]Java Neo4j Cypher Or Match

我有一個圖,用戶可以發帖,也可以有一個朋友發帖,該朋友可以關注也可以不關注。
我如何查詢用戶及其跟隨的朋友的所有帖子?
我嘗試了這個:

  " MATCH (u1:User)-[:POSTED]->(p1:Post)"
+ " WHERE u1.username =~ '"+user+"'"
+ " OPTIONAL MATCH (u3:User)-[:FOLLOWING]->(u2:User)-[:POSTED]->(p2:Post),"
+ " (u3:User)-[:FRIEND_OF]->(u2:User)"
+ " WHERE u3.username =~ '"+user+"' return u1.username, u1.name,"
                        + "p1 ,u2.username, u2.name , p2";

但是此查詢返回重復項,可以說我們有我們的用戶和一個朋友。
朋友有一個帖子而用戶有兩個,則查詢返回朋友帖子兩次,就像每個MATCH一樣 ,查詢還返回OPTIONAL MATCH的結果。

進一步exaplain:

(u:User)-[:POSTED]->(p:Post)
(u:User)-[:FRIEND_OF]->(u2:User)
(u:User)-[:FOLLOWING]->(u2:User)-[:POSTED]->(p2:Post)

這些是存在的關系,我想要的是滿足這些關系的所有帖子(:Post),這些重復不重復,最好是使用單個查詢。

首先,您的查詢比需要的要復雜得多。 這個更簡單的查詢應該是等效的。 我假設{user}作為參數提供

MATCH (u1:User {username: {user}})-[:POSTED]->(p1:Post)
OPTIONAL MATCH
  (u1)-[:FOLLOWING]->(u2:User)-[:POSTED]->(p2:Post),
  (u1)-[:FRIEND_OF]->(u2)
RETURN u1.username, u1.name, p1, u2.username, u2.name, p2;

獲得具有相同p2值的多行的原因是因為RETURN子句將一起返回與u1u2相關的值。 如果有N u1 / p1個結果和M u2 / p2個結果,那么您將得到N*M結果行。

要獲得N行的結果(每個u1/p2結果一行),可以使用以下查詢:

MATCH (u1:User {username: {user}})-[:POSTED]->(p1:Post)
OPTIONAL MATCH
  (u1)-[:FOLLOWING]->(u2:User)-[:POSTED]->(p2:Post),
  (u1)-[:FRIEND_OF]->(u2)
RETURN
  u1.username, u1.name, p1,
  COLLECT({username: u2.username, name: u2.name, p2: p2}) AS friends;

每個結果行將有一個friends集合,其中包含每個相關好友的數據。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM