Neo4J create temp variable within Cypher

ErocCatlun picture ErocCatlun · Feb 6, 2015 · Viewed 7.5k times · Source

So my Top-Level problem is I am trying to return whether a MERGE resulted in the creation of a new Node or not.

In order to do this I was thinking I could just create a simple temp boolean setting it to TRUE using ON CREATE

How I imagine it working:

MERGE(: Person {id:'Tom Jones'})
WITH false as temp_bool
ON CREATE set temp_bool = true
RETURN temp_bool

Obviously this does not work.

I am looking for a way to create arbitrary temp values within a Cypher query, and have the ability to return those variables in the end.

Thanks

Answer

FrobberOfBits picture FrobberOfBits · Feb 6, 2015

You can do what you want, here's how (combination of my first answer, with @cybersam's addition). You just do it with a node property you create and then remove, instead of an unbound variable as you've been trying.

MERGE(tom:Person {id:'Tom Jones'})
ON CREATE set tom.temp_bool = true
ON MATCH set tom.temp_bool = false
WITH tom, tom.temp_bool AS result
REMOVE tom.temp_bool
RETURN result;