How to except (remove) a node in a path in Cypher

Hi,

Letme explain above query:

I want to get all child events of a grandpa event (orange node). First I identify grandpa by where statement, then I use relation SubEvent to get all child-level-1 of grandpa. Then that's is the basic path of returned path. To full fill the that path, I continue expand the path by other relation (there are only Sub, Causal, Result and Next are relations between event. (other uncased relation are role of events which are Entities) But the above query return path included grandpa (which I don't want) I get consfused the path = (e1)--... from it should start from e1 why it include (e),

Second it would be really nice if you help me to shorten or optimize the query, as that query runs quite long. (Like 2 seconds in a graph just have ~4000 nodes and ~4000 relations )

To make it clearer this is directional graph:r
if (a)->(b) it should be read as the ... of a is b e.g: (a)-sub->(b): the subevent of a is b/ or a has subevent which is b. / (a)-causal->(b) : the reason (a) occurred is b/ or a has causal which is b.

I don't see a ten_goi relationship in your graph, so I am not sure how you got any results.

Ignoring that, I believe because you have SubEvent in both matches on lines 2 and 3 (without direction), you are getting 'e' returned in the match on line 3 as the 'c' variable. I think one way to avoid this is to combined the two matches into one match statement. This would avoid the same relationship being traversed twice, as that is not allowed in a single match statement.

1 Like