Clone nodes
The available procedures are described in the table below:
|
clone nodes with their labels and properties |
|
clone nodes with their labels, properties and relationships |
Example Usage
The examples below will help us learn how to use these procedures.
Clone nodes only
The following creates a graph with two nodes, Foo and Bar:
CREATE (f:Foo{name:'Foo'}),(b:Bar{name:'Bar'})
data:image/s3,"s3://crabby-images/eecb9/eecb9d3781116b88517807b9985380abb2890bd8" alt="apoc.refactor.cloneNodes.dataset"
The following creates copies of both of these nodes:
MATCH (f:Foo{name:'Foo'}),(b:Bar{name:'Bar'})
CALL apoc.refactor.cloneNodes([f,b])
YIELD input, output
RETURN *
If we execute this query, it will result in the following graph:
data:image/s3,"s3://crabby-images/be310/be310ecb4c88901f8c5ffa8a008acf6340701fb2" alt="apoc.refactor.cloneNodes"
Clone nodes with relationships
The following creates a graph containing two different nodes of type
Actor
connected with other two different node of type Movie
CREATE (k:Actor {name:'Keanu Reeves'})-[:ACTED_IN {role:'Neo'}]->(m:Movie {title:'The Matrix'}),
(t:Actor {name:'Tom Hanks'})-[:ACTED_IN {role:'Forrest'}]->(f:Movie {title:'Forrest Gump'})
RETURN *
data:image/s3,"s3://crabby-images/c5d37/c5d37f3f3b6a5d526addcb3c8593c03f8b63d95f" alt="apoc.refactor.cloneNodesWithRelationships.dataset"
The following creates copies of both of these nodes and their relationships:
MATCH (k:Actor {name:'Keanu Reeves'}), (t:Actor {name:'Tom Hanks'})
CALL apoc.refactor.cloneNodesWithRelationships([k,t])
YIELD input, output
RETURN *
As result we have a copy of the nodes and relationships
data:image/s3,"s3://crabby-images/d4272/d427224aec23b6239b97d747d4032078c62c4432" alt="apoc.refactor.cloneNodesWithRelationships"