我已经阅读了该文档,发现花括号通常用于形成子查询,或者可以用于描述节点或关系的属性。
但是我注意到有时花括号是分开使用的,我不明白它到底在做什么。
下面是单独使用的花括号的一些示例:
MATCH (p:Person)
RETURN
p,
p.name AS name,
toUpper(p.name),
coalesce(p.nickname, 'n/a') AS nickname,
{name: p.name, label: head(labels(p))} AS person // what is this sentence doing?
MATCH (e:Entity)-[r1:{}]-(t1:Entity)
WHERE e.lid IN {{qids}} AND e.name <> ""
WITH e, r1, t1
OPTIONAL MATCH (t1)-[r2]-(t2:Entity)
WHERE t1.name = ""
AND t2.name <> ""
AND t2 <> e
WITH e, r1, t1, r2, t2
WHERE t1.name <> "" OR (t2 IS NOT NULL AND t2.name <> "")
RETURN e,
{ name : r1.name, labelId: r1.labelId, type: type(r1) } as r1, // this
t1,
{ name : r2.name, labelId: r2.labelId, type: type(r2) } as r2, // and this
t2
ORDER BY t2.score IS NOT NULL DESC, t1.score IS NOT NULL DESC,
t2.score DESC, t1.score DESC
LIMIT 20
先谢谢你!
2条答案
按热度按时间vuktfyat1#
您实际上是在创建键值对的Map。
rjzwgtxy2#
凯文的答案是正确的。
也可能对您有帮助:Neo4j: Cypher WHERE Clause vs. Curly Braces in MATCH Clause - Which is Better?
您也可以参考https://neo4j.com/developer/cypher/querying/