5

假设我想从我的数据库中获取一些顶点:

g.V(1, 2, 3)

然后我有另一组顶点:

g.V(4, 5, 6)

想象一下,它不仅仅是g.V(),而是一些更复杂的遍历来获取我的顶点。但是遍历必须以 开头V(),因为我想从所有节点中进行选择。

让我们也假设我想多次这样做。所以我可能想合并 7 个不同的结果集。每个人都可以有完全不同的方式来获得结果。


现在我想将这两个结果合并到一个结果集中。我的第一个想法是这样的:

g.V(1, 2, 3).fold().as('x').V(4, 5, 6).fold().as('x').select(all, 'x').unfold()

但这不起作用。第二次调用fold将清除我的“局部变量”,因为这是一个障碍步骤。

我目前的尝试是这样的:

g.V(1, 2, 3).fold().union(identity(), V(4, 5, 6).fold()).unfold()

这可行,但看起来有点太复杂了。如果我想重复 7 次,那将是一个非常复杂的查询。

有没有更好的方法来完成来自两个不同查询的结果的简单合并?

4

2 回答 2

5

如何使用aggregate()

gremlin> g.V(1,2,3).aggregate('x').fold().V(4,5,6).aggregate('x').cap('x')
==>[v[1],v[2],v[3],v[4],v[5],v[6]]
gremlin> g.inject(1).union(V(1,2,3).aggregate('x'),V(4,5,6).aggregate('x')).cap('x')
==>[v[1],v[2],v[3],v[4],v[5],v[6]]

你的问题中没有特定的遍历,所以我不得不想出一些人为的例子,但这里的重点是你可以使用aggregate()副作用特定步骤的输出到List你可以cap()在结束时输出结果是您的遍历。

于 2020-01-28T11:37:45.547 回答
4

我的建议是您当前的方法,实际上,我不认为这会比任何其他解决方案更复杂。事实上,我认为无论添加多少分支,它都非常简单。

g.V(1, 2, 3).fold().
  union(identity(),
        V(4, 5, 6).fold(),
        V(7, 8, 9).fold(),
        ...).unfold()
于 2020-01-29T06:10:10.807 回答