Neo4J create temp variable within Cypher

社会主义新天地 提交于 2019-12-04 03:45:53

问题


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


回答1:


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;



回答2:


In simple merging cases like this where maximum one node could be created, a cleaner way to achieve what you are looking for could be checking the result stats. I case of using Bolt API you should check:

results.consume().counters.nodes_created = 1


来源:https://stackoverflow.com/questions/28375229/neo4j-create-temp-variable-within-cypher

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!