2

问题

我正在运行一个查询,该查询通过name属性查找重复的顶点。我想知道所有相应顶点的 ID。

此时只返回 where 子句中的 id。

示例图

这是一个玩具示例图。有两个同名的顶点ex

==>tinkergraph[vertices:0 edges:0]
gremlin> g = graph.traversal()
==>graphtraversalsource[tinkergraph[vertices:0 edges:0], standard]
gremlin> g.addV('X').property('name', 'ex')
==>v[0]
gremlin> g.addV('Y').property('name', 'why')
==>v[2]
gremlin> g.addV('Y').property('name', 'ex')
==>v[4]
gremlin> g.V().elementMap()
==>[id:0,label:X,name:ex]
==>[id:2,label:Y,name:why]
==>[id:4,label:Y,name:ex]

检测重复项

当我找到重复项并获得 时elementMap(),ID 仅适用于where子句中匹配的顶点。

gremlin> g.V().hasLabel('X').as('x').V().hasLabel('Y').as('y').where('x', P.eq('y')).by('name').elementMap()
==>[id:4,label:Y,name:ex]

而我想看看这id两个将是id:0id:4

我想要类似的东西:

==>[[id:0,label:X,name:ex], [id:4,label:Y,name:ex]]
4

1 回答 1

3

你实际上已经非常接近了

gremlin> g.V().hasLabel('X').as('x').
......1>   V().hasLabel('Y').as('y').
......2>   where(eq('x')).by('name').
......3>   select('x','y').
......4>     by(valueMap().by(unfold()).
                with(WithOptions.tokens)).
......5>   select(values)

==>[[id:0,label:X,name:ex],[id:4,label:Y,name:ex]]     
于 2020-05-28T00:43:46.447 回答