如何在生成图-sun的Cypher中编写查询?我指的是中心的一个节点,它与每个节点都有边,但是另一个节点(中心外)本身并不连接。
此外,我希望每个节点都有一些随机属性,比如rank。然后,如何编写查询,找到中心节点(给定等级)更好的10邻居?
有人能给出这样的东西吗?
发布于 2018-05-10 13:52:30
您可以使用这样的查询:
create (center:Center),
(:Node{rank : rand()})-[:LINKED_TO]->(center),
(:Node{rank : rand()})-[:LINKED_TO]->(center),
(:Node{rank : rand()})-[:LINKED_TO]->(center),
(:Node{rank : rand()})-[:LINKED_TO]->(center),
(:Node{rank : rand()})-[:LINKED_TO]->(center),
(:Node{rank : rand()})-[:LINKED_TO]->(center),
(:Node{rank : rand()})-[:LINKED_TO]->(center)若要生成此图表:

注意使用兰德()函数为每个节点中的rank属性分配随机值。
要获得基于rank属性的顶级节点,可以使用以下方法(在本例中,前5位):
match (:Center)<-[:LINKED_TO]-(n:Node)
with n order by n.rank desc limit 5
return n编辑
这里有一个更优雅(但很复杂)的解决方案,用APOC过程apoc.periodic.iterate创建“图形太阳”。我使用一个参数来确定邻居的数量。文档 about apoc.periodic.iterate说:
使用apoc.periodic.iterate提供两个语句,第一个外部语句提供要处理的值流。第二个内部语句一次处理一个元素,或者使用iterateList处理:真,一次处理整个批处理。
因此,在第一个语句中,我返回number_of_n项(使用范围())函数。然后执行第二个语句的number_of_n次数,创建每个邻居。
CALL apoc.periodic.iterate(
"with range(0, {number_of_n} - 1) as items
unwind items as item
return item",
"merge (center:Center)
create (:Node{rank : rand()})-[:LINKED_TO]->(center)",
{params : {number_of_n:20}})此查询输出的图形如下:

https://stackoverflow.com/questions/50267636
复制相似问题