In my Neo4j database I have a following entities:
@NodeEntity
public class Product {
private final static String CONTAINS = "CONTAINS";
private final static String DEFINED_BY = "DEFINED_BY";
private final static String VOTED_FOR = "VOTED_FOR";
private final static String PARENT = "PARENT";
private final static String CREATED_BY = "CREATED_BY";
@GraphId
private Long id;
@RelatedTo(type = PARENT, direction = Direction.INCOMING)
private Product parent;
@RelatedTo(type = CONTAINS, direction = Direction.OUTGOING)
private Set<Product> childProducts = new HashSet<>();
@RelatedTo(type = DEFINED_BY, direction = Direction.INCOMING)
private Set<Criterion> criterias = new HashSet<>();
@RelatedTo(type = VOTED_FOR, direction = Direction.INCOMING)
private Set<Vote> votes = new HashSet<>();
@RelatedTo(type = CREATED_BY, direction = Direction.OUTGOING)
private User user;
}
@NodeEntity
public class Criterion {
private final static String CREATED_BY = "CREATED_BY";
private final static String DEFINED_BY = "DEFINED_BY";
@GraphId
private Long id;
@RelatedTo(type = DEFINED_BY, direction = Direction.OUTGOING)
private Product owner;
@RelatedTo(type = CREATED_BY, direction = Direction.OUTGOING)
private User user;
}
@NodeEntity
public class Vote {
private static final String VOTED_ON = "VOTED_ON";
private final static String VOTED_FOR = "VOTED_FOR";
private static final String CREATED_BY = "CREATED_BY";
@GraphId
private Long id;
@RelatedTo(type = VOTED_FOR, direction = Direction.OUTGOING)
private Product product;
@RelatedTo(type = VOTED_ON, direction = Direction.OUTGOING)
private Criterion criterion;
@RelatedTo(type = CREATED_BY, direction = Direction.OUTGOING)
private User user;
}
Product
is a composite entity and can contain child Products
.
Starting from some Product
node in the hierarchy I need to delete all Votes
on this Product
and then I need to recursively delete all child Products
, Criteria
defined by these nodes and Votes
. User
nodes must not be deleted.
I have tried this Cypher query:
MATCH (p:Product)-[r:CONTAINS*]-(e) WHERE id(p) = {productId} FOREACH (rel IN r| DELETE rel) DELETE e
but it deletes only Products and doesn't delete Votes on the start node and all child Criteria and Votes. Please help me with a correct Cypher query. Thanks.