Dynamic property value based on query
05-10-2021 05:12 AM
Is there any way to add a dynamic node property that is calculated at query time?
e.g. for nodes Alice and Bob, if there is a relationship of type "LOVES" between Alice and Bob then a dynamic property "description" could return value "Alice loves Bob"
based on a query below
MATCH p=(a)-[r]->(b) WITH r, apoc.text.format("%s %s %s", [a.label,apoc.text.replace(toLower(type(r)),'_',' '),b.label]) AS output SET r.description = output RETURN id(r), output
Obviously I can store this as a static property but wondering if possible to generate this at query time rather than storing in db or processing in a client. I can't see any way to set up this as a stored procedure or otherwise. Is this kind of thing doable?
- Labels:
-
Procedures-and-APOC
05-10-2021 06:52 AM
Hi @michela ,
If I understand correctly, you're describing the difference between a spreadsheet cell which contains a value versus one that has a formula introduced with =
. Is that right?
Some day that might be possible by defining a view on the graph.
Until then, you could write a user-defined-function which accepts a path as a parameter and returns a map of values. See UserFunction (Neo4j 4.2.3 API)
Best,
ABK