1

我处于需要使用单个查询获取两种不同类型的顶点的情况。例如,假设图具有以下结构:

Node("User")--Edge("is_member")-->Node("Membership")--Edge("is_member")-->Node("Group")

假设节点具有以下属性:

  1. 会员资格
    • 地位
    • 日期
  2. 团体
    • 姓名
    • 日期
    • 类型

现在,我需要获取Membership用户的所有节点is_member,以及相应Groupname. 我该如何为此编写 Gremlin 查询?

我正在使用灯泡框架。如何将结果存储在 python 对象中?

4

1 回答 1

1

以下查询为用户提供u1了一个带有key = Membership-Nodes 和的地图value = list of group names of the key membership node

m=[:];u1.out('is_member').groupBy(m){it}{it.out('is_member').name}

输出是:

gremlin> m
==>v[m1]=[group1]
==>v[m2]=[group2, group3]

这里使用的示例图:

g = new TinkerGraph()
u1 = g.addVertex('u1')
u2 = g.addVertex('u2')
m1 = g.addVertex('m1')
m2 = g.addVertex('m2')
g1 = g.addVertex('g1')
g2 = g.addVertex('g2')
g3 = g.addVertex('g3')

g.addEdge(u1, m1, 'is_member')
g.addEdge(u1, m2, 'is_member')
g.addEdge(u2, m2, 'is_member')
g.addEdge(m1, g1, 'is_member')
g.addEdge(m2, g2, 'is_member')
g.addEdge(m2, g3, 'is_member')

g1.name = 'group1'
g2.name = 'group2'
g3.name = 'group3'

另请参阅:如何编写子查询?

(用 gremlin2 测试)

于 2015-02-18T12:46:21.847 回答