![精通Neo4j](https://wfqqreader-1252317822.image.myqcloud.com/cover/113/47216113/b_47216113.jpg)
3.2.8 列表
Cypher对列表(List)有很好的支持。
3.2.8.1 概述
可以使用方括号和一组以逗号分隔的元素来创建一个列表。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P122_87887.jpg?sign=1738882268-hAuTYnoOqhPVefJbOxCnOqdDPrMWSpwn-0-b58fffec29e98be483b848c780530482)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P122_101454.jpg?sign=1738882268-YUR6GEOYjEmiE1an3q7uLfvgqLWqaQO0-0-1627b1c4219a4e469a12cf9072f53a06)
下面的例子使用range函数创建列表。它指定了列表包含元素的开始数字和结束数字。范围的两端也是包含在内的,例如:
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_87898.jpg?sign=1738882268-uwuQaAbf7WpjA8IaODOqcx4OeRp7LXyQ-0-f3df98e69488521a15a1948fe1fdf332)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_102546.jpg?sign=1738882268-ID5NrNM1P5rvWtavVlJovbjkdAVGV3KG-0-a92bdd092520ceb55fce2b8123df9f55)
可以使用方括号[]访问列表中的元素。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_87905.jpg?sign=1738882268-Nxs2IYBiuT05AmyjwJUFWN3uUZPxFVjv-0-07d69b6dc442ba58a100838dd961b8c6)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_102547.jpg?sign=1738882268-THDsx4rDj1pd1puPV9gIlfRNtA3TRJ1R-0-47a5f518bce090b15973146fc500a5fe)
索引也可以为负数,这时将以列表的末尾作为开始点访问。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_87912.jpg?sign=1738882268-qynDp4uLJ0sV0bKk5EAbX8dcORdObS1E-0-9a936a5539cb85087d6f744f49f5edc1)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_102548.jpg?sign=1738882268-wTxuOqvlae8TpnzMe4QnioT7ccxdyuFd-0-0fdd64a33263903d8d416c89082d05a7)
也可以在[]中指定列表返回指定范围的元素。它将提取开始索引到结束索引的值,但不包含结束索引所对应的值。如下面例子中,开始索引为0,结束索引为3,结果将返回索引0、1、2对应的值,但不会返回结束索引3对应的值。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_87919.jpg?sign=1738882268-CmKevjHaBh6nIR0jCfnKupswkNnt1lY5-0-416d459b6bff46cbebadb66193140b64)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P123_101466.jpg?sign=1738882268-CLbjGH6U6QdMuKTZFL23WQJA6DigQd1R-0-bfad5b38acb4fdf3426a49680ba442c8)
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_87930.jpg?sign=1738882268-PYmjm9hnYkpPEEdqzwDd4931CbA6fT6o-0-ad4f2ef45dc8af5581bcf0eaf0baf0a3)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_101469.jpg?sign=1738882268-tVTqOcL3bAqLqudCCSNk8e9b05nEateM-0-f1a4e3ae5197834ff7c1d74e8c896e0b)
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_87937.jpg?sign=1738882268-t9hjJdSQKkLJnA8hEMnGsLsALUjrNnfI-0-7ab51aeab923dff42b6e06be0ea5a4a4)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_101472.jpg?sign=1738882268-LatMR65itWwhBV8WDmOVP1pxzFD7flhg-0-6f0e22adce382af2f8363051fe024190)
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_87944.jpg?sign=1738882268-6nGgw0JR56dxaByDkmvyQoKhhXGZXmm4-0-c5bbd146e2fa5032714a44f69a971065)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_102549.jpg?sign=1738882268-YqB2OIgih04ck5xnHcbkv7nDYWZ4vKfK-0-eaaf857ea2121dc1c060cf7f0d1f9b68)
注意:如果是一个range的索引值越界了,那么直接从越界的地方进行截断以返回结果。如果是单个元素的索引值越界了,则返回null。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_87951.jpg?sign=1738882268-hmjqAQc6nODgYbQGi7WONhfwzFq72qJf-0-acadbdad79a529c7450f61dfb1a67f4a)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_101477.jpg?sign=1738882268-qMuJuo10Adr6pGI9mAzU87p1Sp6UTXoq-0-fec630c79c4dfd623d03b166d2226067)
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P124_87958.jpg?sign=1738882268-PXz2XQ19IuoEhQnYYq5tACBQuAHbar0b-0-c608934fb7c990e431b5e5d61151150f)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_102551.jpg?sign=1738882268-o8YB26qzarkWRDI7jtK87AvrR6P6xnf2-0-6e731252aa13113bbb6cb650e2337402)
可以用size函数获取列表的长度,例如:
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_87969.jpg?sign=1738882268-N7Hpcc6Ftvm3ZTuSp7Za55tKbBleqsYq-0-84cdb578d60ff17adc60eeb19bfa9c84)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_101482.jpg?sign=1738882268-VChU2wOMCWBGND4J6SAaAtrXMlm8PdGf-0-379d5d67c345747603a7b6917d64bb82)
3.2.8.2 List推导式
List推导式(Comprehension)是Cypher基于现有列表创建列表的一种语法构造。它遵循数学上的集合,替代映射和过滤函数。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_87976.jpg?sign=1738882268-7PTlJDCJdRyCDNF9njSlnnWJKfDZe1pD-0-d6826995c717a1c8357e68a00b5bf003)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_102552.jpg?sign=1738882268-7VOkz9k1dMkUPw6NEogyJWzcZyBpd5hs-0-058fd799e3d473fb85ba24bab60233ed)
如果希望分别过滤或映射,WHERE部分或者表达式部分都是可以省略的。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_87983.jpg?sign=1738882268-mtuNDMOMjde3XDVlO37cX75tCF3WzKpo-0-e79bd1bf528575b16f95286c9693232c)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_101488.jpg?sign=1738882268-VSNqpKaKQ5DicVl4wPoylJPPa3IQ1i8z-0-eeea4e0e999516d98f28073219bc1c7c)
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P125_87990.jpg?sign=1738882268-6N25OI932ksi1o9iOFSgWRjr2OhcVNeo-0-3493a897a464fbdb5582d5c87e7dd18c)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P126_101490.jpg?sign=1738882268-TE5zz4Pk9Q9tmaKvy1oAQUxLeFqoozZW-0-864591636486b6ae929b50b452bead4f)
3.2.8.3 模式推导式
模式推导式是Cypher基于模式匹配的结果创建列表的一种语法构造。模式推导式将像一般的MATCH语句那样去匹配模式,断言部分与一般的WHERE语句一样,但它将产生一个指定的图制投射。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P126_102553.jpg?sign=1738882268-EKIieZQB7DkaQrdZn7UMKa8QYIEa8Kyl-0-6359bf98fbd94166c07256be935bda12)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P126_102554.jpg?sign=1738882268-PwV83UOkvQHdxwLEi4PCzE0bhaDeEUOJ-0-72a4a065d2e6dce881a36e5467d37e35)
整个断言,包括WHERE关键字都是可选的,可以被省略。
3.2.8.4 字面值映射
Cypher也可以构造映射。通过REST接口可以获取JSON对象。在Java中对应的是java.util.Map<String, Object>。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P126_88014.jpg?sign=1738882268-b6aXkiIj6TlcO4mlujea3feYB0778fG4-0-e38ba02c75a53155cdac0f5b2386b2df)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P126_101496.jpg?sign=1738882268-R3oTVLJVP0le9jcUJiHJDKoPTstS1SdK-0-fe9aeef9163a4785b15b2a187d977c0f)
3.2.8.5 Map投射
Cypher支持一个名为“map projections”(Map投射)的概念。它使得基于已有节点、关系和其他map值来构建map变得容易。
Map投射以指向图实体且用逗号分隔的变量簇开头,并包含以{}包括起来的映射元素。其语法如下:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P127_88023.jpg?sign=1738882268-YrN7zQG9YcFMHTFWEsNJgv9xdXXrE4Iq-0-3b07ef9a763be6186a04b67422f23a73)
一个map元素投射一个或多个键值对到map投射。这里有4种类型的map投射元素:
● 属性选择器:以投射属性名作为键,map_variable中对应键的值作为键值。
● 字面值项:来自任意表达式的键值对,如key: <expression>。
● 变量选择器:投射一个变量,变量名作为键,变量的值作为投射的值。它的语法只有变量。
● 全属性选择器:射来自map_variable中的所有键值对。
提示:提示:如果map_variable的值指向一个null,那么整个map投射将返回null。
举一个投射的例子。找到Charlie Sheen和返回关于他和他参演过的电影。这个例子展示了字面值项类型的map投射,反过来它还在聚合函数collect()中使用了map投射。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P127_102555.jpg?sign=1738882268-tCHs0fkUdW2UhtoJOTvIYAt9WPwBaW7K-0-10975648ad6e49eddf5ace3af8ddf859)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P127_102558.jpg?sign=1738882268-fti5TApEtdYhQ79wmGq7azVAlTrVJr9S-0-b0ad51e5b80ccecd332f4131b88ba1a6)
以上例子找出演过电影的所有演员,并显示他们所参演电影的数量。这个例子用一个变量来代表数量,使用变量选择器来投射值,如下所示:
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P127_102556.jpg?sign=1738882268-ZWkPBDJB5KKTXqZDA8TWtNXXRaR2GKTE-0-b75dbcb0dfc5fa0b2f40457ada0168c1)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P127_102559.jpg?sign=1738882268-NKXHrnB8ymhOHfsdbJiQrRhF79pQPP1b-0-3e6eb0d5284e405152f1bcedf07d884e)
还是以“Charlie Sheen”为例,下面查询语句将返回该节点的所有属性。这里使用了全属性选择器来投射所有的节点属性和一个额外的显式投射的age属性。因为此属性在该节点不存在,所以投射的值为null。
查询:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P127_88062.jpg?sign=1738882268-qe9OZcQiEq0ftXdUeavXJ3tnwQU23EJT-0-8004ccf86b539e456eb7c07b6b176926)
结果:
![](https://epubservercos.yuewen.com/84FE89/26581284601284906/epubprivate/OEBPS/Images/Figure-P128_101505.jpg?sign=1738882268-PUbdrFafqxVB3geMj5EgmS5spgEMf1Ev-0-8b662e8e05ef30ee1b7fb1aa507c2b89)