AWS Neptune 查找节点的所有祖先

时间:2021-07-01 17:48:12

标签: amazon-web-services gremlin 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()

1 个答案:

答案 0 :(得分:1)

您需要做的就是在 emit() 之后添加一个 repeat() step 或者像这样在查询的末尾添加 path() step,取决于您是想要返回顶点还是返回路径:

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()

相关问题