如何在gremlin中输出与其邻居的当前顶点?

时间:2014-07-28 21:20:22

标签: graph gremlin titan nosql

我正在尝试在图表上进行复杂查询,并且能够成功完成。在该查询中输出的顶点也有一些通过别名关系连接到这些顶点的别名顶点。

现在我希望用它们的别名顶点输出所有以前的顶点,但我可以做/或(原始顶点或每个顶点的别名顶点)。

如果有人知道输出特定顶点的相邻顶点的方法,并在同一查询中输出该顶点,我认为我的问题将得到解决。

有什么建议吗?

1 个答案:

答案 0 :(得分:3)

让我们考虑以下示例:

[AliasUser1]< ---'别名'--- [User1] ---'喜欢'---> [ItemA]< ---'喜欢'--- [User2] ---'别名'---> [AliasUser2]

使用以下代码:

result = [] as Set;
user1.out('likes')  // we are at ItemA
     .in('likes')   // we are at User2 but also back at User1
     .store(result) // store the users vertices
     .out('alias')  // we are at the alias vertices 
     .store(result) // store the alias vertices
     .iterate()     // run

你得到:

gremlin> result.name
==>User2
==>AliasOfUser2
==>User1
==>AliasOfUser1

所以我猜store是解决问题的关键。

以下是示例的示例图:

g = new TinkerGraph()

user1 = g.addVertex()
user1.name ='User1'
user2 = g.addVertex()
user2.name ='User2'
itemA = g.addVertex()
itemA.name ='ItemA'
myAlias1 = g.addVertex()
myAlias1.name ='AliasOfUser1'
myAlias2 = g.addVertex()
myAlias2.name ='AliasOfUser2'

g.addEdge(user1, itemA, 'likes')
g.addEdge(user2, itemA, 'likes')
g.addEdge(user1, myAlias1, 'alias')
g.addEdge(user2, myAlias2, 'alias')