有些事情我没有通过密码查询和多个匹配得到。Neo4j/Cypher:在密码查询中出现多个匹配问题
语境:
目标=节点(2145)=视频游戏上的应用程序
我=节点(2570)=用户登录
我试图让所有的与给定目标交互的用户(包括我)。 此外,我希望这些用户按照他们和我之间的距离排序......
即,其目标是显示与视频游戏互动的用户:我和我的朋友,然后是其他人。
我的查询:
START target=node(2145), me=node(2570)
MATCH (target)-[:INTERACTIONS]->()<-[:IS_TARGET_OF]-(interactions)<-[:IS_SOURCE_OF]-()<-[:INTERACTIONS]-(users)
WITH me, users
MATCH p = (users)-[:CONTACTS]->()-[?:IS_FRIEND_WITH*0..3]-()<-[:CONTACTS]-(me)
RETURN users, MIN(LENGTH(p)) as conn
ORDER BY conn ASC
问题:
考虑,我与目标交互的唯一一个,我应该得到一个结果:2570
我遇到的问题是我在返回的用户中看不到'我':查询不会返回任何内容
我的尝试:
- 如果我第一场比赛之后回来,我得到一个结果:2570
如果在第二场比赛,我尝试P =(用户) - [* 0..3] - (我),我也得到一个结果:2570
如果我只需要在查询的第二部分尝试以下操作:
START me=node(2570), users=node(2570, 2802) MATCH p = me-[:CONTACTS]->()-[?:IS_FRIEND_WITH*0..3]-()<-[:CONTACTS]-(users) RETURN users, MIN(LENGTH(p)) as conn ORDER BY conn ASC
我得到2570和2802(因为他是我的朋友)。
我确定我在这里做错了什么,但我看不到什么......你有什么想法我可以解决我的问题吗?
感谢,
非常感谢Lisa,我用你的查询结合了第二场比赛和第一场比赛,这完美地奏效了。再一次,你的解释很清楚,谢谢! – Brice