首页 > 解决方案 > AWS Neptune 查找节点的所有祖先

问题描述

我使用 Jupyter notebook 将以下顶点和边插入 Neptune 数据库。

%%gremlin

g.addV('my').property(T.id, '1').next()
g.addV('my').property(T.id, '2').next()
g.addV('my').property(T.id, '3').next()
g.addV('my').property(T.id, '4').next()
g.addV('my').property(T.id, '5').next()
g.addV('my').property(T.id, '6').next()
g.addV('my').property(T.id, '7').next()
g.addV('my').property(T.id, '8').next()

g.V('1').addE('parent').to(g.V('2')).next()
g.V('2').addE('parent').to(g.V('3')).next()
g.V('3').addE('parent').to(g.V('4')).next()
g.V('4').addE('parent').to(g.V('5')).next()

g.V('1').addE('parent').to(g.V('6')).next()
g.V('6').addE('parent').to(g.V('7')).next()
g.V('7').addE('parent').to(g.V('8')).next()

然后我使用以下查询来查找节点“1”的所有祖先。但是,它只返回节点“5”和注释“8”,以及最高级别的祖先。

如何修改查询以获取所有中间祖先,如“2”、“3”、“4”、“5”、“6”、“8”

%%gremlin -p v,oute,inv
g.V('1').repeat(out('parent')).until(outE('parent').count().is(0)).toList()

标签: amazon-web-servicesgremlinamazon-neptune

解决方案


您需要做的就是在查询之后添加一个emit() 步骤repeat()或将path() 步骤添加到查询的末尾,这取决于您是否想要顶点或返回的路径:

g.V().hasLabel('a').repeat(out('parent')).until(outE('parent').count().is(0)).emit()

g.V().hasLabel('a').repeat(out('parent')).until(outE('parent').count().is(0)).path()


推荐阅读