Create Dynamic Relationships With APOC
See how the APOC library can be used to automatically create relationships when loading data.
Join the DZone community and get the full member experience.
Join For FreeOne of the things I’ve often found frustrating when importing data using Cypher, Neo4j’s query language, is that it’s quite difficult to create dynamic relationship types.
Say we have a CSV file structured like this:
load csv with headers from "file:///people.csv" AS row
RETURN row
╒═══════════════════════════════════════════════════════╕
│row │
╞═══════════════════════════════════════════════════════╡
│{node1: Mark, node2: Reshmee, relationship: MARRIED_TO}│
├───────────────────────────────────────────────────────┤
│{node1: Mark, node2: Alistair, relationship: FRIENDS} │
└───────────────────────────────────────────────────────┘
We want to create nodes with the relationship type specified in the file. Unfortunately, in Cypher we can’t pass in relationship types so we have to resort to the FOREACH hack to create our relationships:
load csv with headers from "file:///people.csv" AS row
MERGE (p1:Person {name: row.node1})
MERGE (p2:Person {name: row.node2})
FOREACH(ignoreMe IN CASE WHEN row.relationship = "MARRIED_TO" THEN [1] ELSE [] END |
MERGE (p1)-[:MARRIED_TO]->(p2))
FOREACH(ignoreMe IN CASE WHEN row.relationship = "FRIENDS" THEN [1] ELSE [] END |
MERGE (p1)-[:FRIENDS]->(p2))
This works, but:
- Looks horrendous
- Doesn’t scale particularly well when we have multiple relationship types to deal with
As in my last post the APOC library comes to the rescue again, this time in the form of the apoc.create.relationship procedure.
This procedure allows us to change our initial query to read like this:
load csv with headers from "file:///people.csv" AS row
MERGE (p1:Person {name: row.node1})
MERGE (p2:Person {name: row.node2})
WITH p1, p2, row
CALL apoc.create.relationship(p1, row.relationship, {}, p2) YIELD rel
RETURN rel
Much better!
Published at DZone with permission of Mark Needham, DZone MVB. See the original article here.
Opinions expressed by DZone contributors are their own.
Comments