如何使用CSV字段在LOAD语句中定义节点标签

时间:2017-07-18 12:31:42

标签: csv neo4j cypher

此示例取自https://neo4j.com/developer/guide-importing-data-and-etl/#_importing_the_data_using_cypher"

LOAD CSV WITH HEADERS FROM "file:customers.csv" AS row
    CREATE (:Customer {companyName: row.CompanyName, customerID: row.CustomerID, fax: row.Fax, phone: row.Phone});

我想要做的是使用CSV文件中的字段来定义节点中的标签。例如:

LOAD CSV WITH HEADERS FROM "FILE:///Neo4j_AttributeProvenance.csv" AS CSVLine CREATE (q:CSVLine.NodeType { NodeID:CSVLine.NodeID, SchemaName:CSVLine.SchemaName, TableName:CSVLine.TableName, DataType:CSVLine.DataType, PreviousNodeID:CSVLine.PreviousNodeID });

Here is the error I get:

1 个答案:

答案 0 :(得分:4)

您应该查看APOC程序。在这种情况下,有一个程序能够根据.csv文件中的列值以dinamically方式创建节点。语法是:

CALL apoc.create.node(['Label'], {key:value,…​})

在您的情况下,最简单的语法应该是:

CALL apoc.create.node(["' + CSVLine.NodeType + '"], {NodeID: "' + NodeID:CSVLine.NodeID + '", etc}) yield node