在Gremlin中,我将如何重定向进入一个顶点的所有边以连接到另一个顶点?

时间:2019-07-22 20:26:49

标签: graph-theory gremlin amazon-neptune

我正在使用Neptune作为图形数据库。

假设我有一个主顶点“ A”,我想将所有指向“ A”的连接重定向到新的主顶点“ B”。我知道进入主顶点的所有边都标记为'master_edge'。

目前我混合使用python和gremlin代码,我想知道是否有办法通过仅在gremlin中执行此操作来提高性能?

vertices_on_deck = g.V(old_master).inE().outV().toList()
          for i, current_vertex in enumerate(vertices_on_deck): 
            if i == 0:
                t = g.addE('master_edge').from_(__.V(current_vertex.id)).to(__.V(new_master))
            else: 
                t.addE('master_edge').from_(__.V(current_vertex.id)).to(__.V(new_master))
          t.iterate()
          g.V(old_master).drop().iterate()

1 个答案:

答案 0 :(得分:1)

您可以将所有查询合并为一个:

g.V(old_master).as('oldMaster')
   .inE().outV().addE('master_edge').to(__.V(new_master))
   .select('oldMaster').drop().iterate()