首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将两个节点之间的多个关系转换为具有权重的单个节点

将两个节点之间的多个关系转换为具有权重的单个节点
EN

Stack Overflow用户
提问于 2018-08-06 17:47:36
回答 1查看 76关注 0票数 0

我有下面的图表,描述汽车品牌在文件中的共现情况:

代码语言:javascript
复制
CREATE 
  (`0` :Car {value:"Ford"})
, (`1` :Car {value:"Subaru"})
, (`2` :Car {value:"VW"})
, (`0`)-[:`DOCUMENT` {value:"DOC-1"}]->(`1`)
, (`0`)-[:`DOCUMENT` {value:"DOC-2"}]->(`1`)
, (`1`)-[:`DOCUMENT` {value:"DOC-3"}]->(`2`);

如果两个节点之间存在许多关系--为了可视化目的--我想用一个节点替换它,并计算权重:

代码语言:javascript
复制
VW ---1--- Subaru ---2--- Ford

如何才能做到这一点?

我尝试了以下查询:

代码语言:javascript
复制
MATCH (n1)-[r1:DOCUMENT]-(n2)
RETURN n1, n2, apoc.create.vRelationship(n1, 'WEIGHT', {weight:count(r1)}, n2);

但这是,而不是预期的结果:

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-06 18:46:18

如果关系方向未在MATCH (n1)-[r1:DOCUMENT]-(n2) RETURN *;中指定,则每个关系将返回两次

代码语言:javascript
复制
╒══════════════════╤══════════════════╤═════════════════╕
│"n1"              │"n2"              │"r1"             │
╞══════════════════╪══════════════════╪═════════════════╡
│{"value":"Ford"}  │{"value":"Subaru"}│{"value":"DOC-1"}│
├──────────────────┼──────────────────┼─────────────────┤
│{"value":"Ford"}  │{"value":"Subaru"}│{"value":"DOC-2"}│
├──────────────────┼──────────────────┼─────────────────┤
│{"value":"Subaru"}│{"value":"Ford"}  │{"value":"DOC-1"}│
├──────────────────┼──────────────────┼─────────────────┤
│{"value":"Subaru"}│{"value":"Ford"}  │{"value":"DOC-2"}│
├──────────────────┼──────────────────┼─────────────────┤
│{"value":"Subaru"}│{"value":"VW"}    │{"value":"DOC-3"}│
├──────────────────┼──────────────────┼─────────────────┤
│{"value":"VW"}    │{"value":"Subaru"}│{"value":"DOC-3"}│
└──────────────────┴──────────────────┴─────────────────┘

通过将MATCH子句更改为MATCH (n1)-[r1:DOCUMENT]->(n2)MATCH (n1)<-[r1:DOCUMENT]-(n2)来指定方向。查询的其余部分是正确的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51713072

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档