我有一个简单的图,有两个顶点,I分别是'a‘和'b’。
我已经分配了一个从'a‘到'b’的边,标签= 'foo‘
gremlin> g.V()
==>vb
==>va
gremlin> g.E()
==>e04b4b9fd-2f20-751d-5673-5aa9d7ce0285
我的问题是:如何沿同一条边向后遍历?例如,如果查询遍历到出站顶点,那么该查询如何穿过相同的边回到入站顶点?
我的查询如下所示:
要获取相同边的inV,请单击此处的g.E('04b4b9fd-2f20-751d-5673-5aa9d7ce0285').outV().as('outV')...want
发布于 2019-03-13 06:51:26
有很多不同的方法可以做到这一点。这里有几个可能会启发你回答问题的方法。在下面的例子中,您可能不应该指望返回折点的顺序,但您可以使用bothV()
gremlin> g.E(11).bothV()
==>v[4]
==>v[3]要强制排序,您可以执行union()
gremlin> g.E(11).union(inV(),outV())
==>v[3]
==>v[4]你可以随时project()你的结果:
gremlin> g.E(11).project('in','out').by(inV()).by(outV())
==>[in:v[3],out:v[4]]如果您需要首先对outV()执行某些操作,然后返回到边缘,然后在inV()上遍历,则可以使用as()标记E()步骤
gremlin> g.E(11).as('e').outV().hasLabel('person').select('e').inV()
==>v[3]希望这些例子能有所帮助。
https://stackoverflow.com/questions/55131625
复制相似问题