簡體   English   中英

如何在Neo4J Cypher查詢中僅從路徑中檢索節點?

[英]How to retrieve only the nodes from the path in Neo4J Cypher query?

我有以下類型的查詢:

MATCH (u1:User{name:"user_name"}), (s1:Statement), s1-[:BY]->u1 
WITH DISTINCT s1,u1 
MATCH (s2:Statement), s2-[:BY]->u1, 
p=s1<-[:OF]-c-[:OF]->s2 
WHERE s1 <> s2 
WITH collect(p) AS coll, count(p) AS paths, s1, s2 
RETURN s1,s2,paths,coll 
ORDER BY paths DESC 
LIMIT 2;

現在,它返回coll變量中所有路徑p的列表。 我希望它僅列出節點c 如何做到這一點?

也許查詢不正確,在這種情況下,我想做的是

1)查找用戶所作的所有陳述;

2)找到連接這兩個語句的節點;

3)返回那些連接最多的節點(ORDER BY DESC)的語句,包括連接它們的實際節點的名稱。

謝謝!

我目前無法測試,但是您可以嘗試類似

MATCH (u:User {name:"user_name"})<-[:BY]-(s1)<-[:OF]-(c)-[:OF]->(s2)-[:BY]->(u)
RETURN s1, s2, collect(c) as connections 
ORDER BY length(connections) DESC 
LIMIT 2

暫無
暫無

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

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