Neo4j 在csv中的两个节点之间创建具有不同属性的多个相同类型的关系
在Neo4jDesktop中的两个节点之间创建具有不同属性的多个相同类型的关系时,我遇到了一个问题Neo4j 在csv中的两个节点之间创建具有不同属性的多个相同类型的关系,neo4j,relationship,Neo4j,Relationship,在Neo4jDesktop中的两个节点之间创建具有不同属性的多个相同类型的关系时,我遇到了一个问题 Nodes dataset: File Name: 1.csv File Contents: Id,Desc A,Alpha B,Beta C,Charlie D,Doyce Relationships Dataset: File Name: 2.csv File Contents:
Nodes dataset:
File Name: 1.csv
File Contents:
Id,Desc
A,Alpha
B,Beta
C,Charlie
D,Doyce
Relationships Dataset:
File Name: 2.csv
File Contents:
SeqNo,Date,Count,Weight,From,To
0,2018-04-01,12,308,A,B
1,2018-04-01,3,475,B,C
2,2018-04-01,23,308,C,D
3,2018-04-01,32,524,D,A
4,2018-04-01,0,308,A,C
5,2018-04-01,23,237,B,D
6,2018-04-01,54,308,B,A
7,2018-04-01,23,237,D,B
8,2018-04-01,18,308,D,C
9,2018-04-01,23,308,C,A
10,2018-04-01,78,475,B,C
11,2018-04-01,67,308,A,B
12,2018-04-01,56,237,D,B
13,2018-04-01,34,308,A,C
14,2018-04-01,27,524,A,D
15,2018-04-01,84,237,D,B
// Create Nodes
USING PERIODIC COMMIT
LOAD CSV WITH HEADERS FROM "file:/1.csv" AS row
CREATE (:Node {Id: row.Id, Desc: row.Desc});
// Create Relationships
USING PERIODIC COMMIT
LOAD CSV WITH HEADERS FROM "file:/2.csv" AS row
MERGE (from:Node {Id: row.From})
MERGE (to:Node {Id: row.To})
MERGE (from)-[rel:RELATED_AS]->(to)
ON CREATE SET rel.SeqNo = toInt(row.SeqNo),
rel.Date = row.flightDate,
rel.Count = toInteger(row.Count),
rel.Weight = toFloat(row.Weight)
此语法有效,仅创建11个关系,两个节点之间有传入和传出关系。
它忽略了A-B、B-C、A-C和D-B之间的附加关系(2个附加关系)。
如何创建包含所有16个关系的图表 提前谢谢
Mel.您的第二个查询正在合并关系
(from)-[rel:RELATED\u AS]>(to)
,因此Cypher将匹配该模式(如果存在)。因此,后面的值是匹配的,但是由于CREATE语句中的,这些值永远不会更新
因为您希望每次都创建关系,所以可以使用以下内容替换您的语句
USING PERIODIC COMMIT
LOAD CSV WITH HEADERS FROM "file:/2.csv" AS row
MERGE (from:Node {Id: row.From})
MERGE (to:Node {Id: row.To})
CREATE (from)-[rel:RELATED_AS {SeqNo: row.SeqNo, Date: row.flightDate, Count: toInteger(row.Count), Weight: toFloat(row.Weight)}]->(to)
欢迎加入。您能否编辑您的问题以正确显示代码块?在代码前使用四个空格,或者在问题编辑器中使用按钮。问题将变得更具可读性和趣味性:)