10

我是 Gremlin 的新手,只是想建立一个基本的图表。我已经能够在新顶点上做一个基本的 addEdge ,即

gremlin> v1 = g.addVertex()
==>v[200004]
gremlin> v2 = g.addVertex()
==>v[200008]
gremlin> e = g.addEdge(v1, v2, 'edge label')
==>e[4c9f-Q1S-2F0LaTPQN8][200004-edge label->200008]

我还能够在通过 id 查找的顶点之间创建一条边:

gremlin> v1 = g.v(200004)
==>v[200004]
gremlin> v2 = g.v(200008)
==>v[200008]
gremlin> e = g.addEdge(v1, v2, 'edge label')
==>e[4c9f-Q1S-2F0LaTPQN8][200004-edge label->200008]

但是,我现在想根据多个属性查找顶点,这就是它变得棘手的地方。为了查找正确的顶点,我对.has. 似乎找到了正确的顶点,但添加边失败。

gremlin> v1 = g.V.has("x",5).has('y",7)
==>v[200004]
gremlin> v2 = g.V.has("x",3).has('y",5)
==>v[200008]

gremlin> e = g.addEdge(v1, v2, 'edge label')
No signature of method: groovy.lang.MissingMethodException.addEdge() is applicable for argument types: () values: []

基于属性值查找,在两个现有顶点之间添加简单边的最简单方法是什么?

4

1 回答 1

17

关键问题是.has返回一个Pipe:为了获取特定的顶点实例,一个简单的调用就.next()可以了:

gremlin> v1 = g.V.has("x",5).has('y",7).next()
==>v[200004]
gremlin> v2 = g.V.has("x",3).has('y",5).next()
==>v[200008]

gremlin> e = g.addEdge(v1, v2, 'edge label')
==>e[4c9f-Q1S-2F0LaTPQN8][200004-edge label->200008]

请注意,这.next()只会返回管道中的下一项。在这种情况下,任何与属性值匹配的附加顶点都将被忽略。

于 2013-06-14T21:41:07.987 回答