gremlin语言介绍八:path查询

2020-07-05  本文已影响0人  生饼

0 打开一个新的图库

本节的命令使用的测试数据是tinkerpop官方提供的Modern图库,使用以下命令可以加载tinkerpop modern图库,它包含6个vertex和6条edge

$ ./bin/gremlin.sh
gremlin> graph = TinkerFactory.createModern()
==>tinkergraph[vertices:6 edges:6]
gremlin>
gremlin> g = graph.traversal()
==>graphtraversalsource[tinkergraph[vertices:6 edges:6], standard]
image.png

1 path

gremlin遍历图时,会经过一系列的vertex和edge,遍历的轨迹形成一条路径,path()则按遍历的顺序返回经过的vertex和edge

下面的查询有两条path,一条经过vertex 1、4、5,节点5的name值为ripple

gremlin> g.V().out().out().values('name').path()
==>[v[1],v[4],v[5],ripple]
==>[v[1],v[4],v[3],lop]

path中如果要返回边,则需要显式的加上遍历edge的step,如下:

gremlin> g.V().outE().inV().outE().inV().path()
==>[v[1],e[8][1-knows->4],v[4],e[10][4-created->5],v[5]]
==>[v[1],e[8][1-knows->4],v[4],e[11][4-created->3],v[3]]

可以通过by()选择path中vertex和edge返回的内容。
下面的查询语句,path中的第一个元素返回它的name值,第二个元素返回它的age值,第三个元素返回它的name,如此递推

gremlin> g.V().out().out().path().by('name').by('age')
==>[marko,32,ripple]
==>[marko,32,lop]

2 simplePath

查询简单路径,过滤掉环路

gremlin> g.V(1).both().both().simplePath().path()
==>[v[1],v[3],v[4]]
==>[v[1],v[3],v[6]]
==>[v[1],v[4],v[5]]
==>[v[1],v[4],v[3]]

3 cyclicPath

查询环路

gremlin> g.V(1).both().both().cyclicPath().path()
==>[v[1],v[3],v[1]]
==>[v[1],v[2],v[1]]
==>[v[1],v[4],v[1]]

4 shortestPath

查询最短无环路径。。注意最短路径计算是OLAP类型的遍历,需要GraphComputer的支持,所有需要使用withComputer()配置遍历

所有vertex对之间的最短路径

gremlin> g.withComputer().V().shortestPath()
==>[v[1],v[2]]
==>[v[1],v[4],v[5]]
==>[v[1],v[4]]
==>[v[1]]
==>[v[1],v[3]]
==>[v[1],v[3],v[6]]
==>[v[2]]
==>[v[2],v[1],v[4],v[5]]
==>[v[2],v[1],v[4]]
==>[v[2],v[1]]
==>[v[2],v[1],v[3]]
==>[v[2],v[1],v[3],v[6]]
==>[v[3],v[1],v[2]]
==>[v[3],v[4],v[5]]
==>[v[3],v[4]]
==>[v[3],v[1]]
==>[v[3]]
==>[v[3],v[6]]
==>[v[4],v[1],v[2]]
==>[v[4],v[5]]
==>[v[4]]
==>[v[4],v[1]]
==>[v[4],v[3]]
==>[v[4],v[3],v[6]]
==>[v[5],v[4],v[1],v[2]]
==>[v[5]]
==>[v[5],v[4]]
==>[v[5],v[4],v[1]]
==>[v[5],v[4],v[3]]
==>[v[5],v[4],v[3],v[6]]
==>[v[6],v[3],v[1],v[2]]
==>[v[6],v[3],v[4],v[5]]
==>[v[6],v[3],v[4]]
==>[v[6],v[3],v[1]]
==>[v[6],v[3]]
==>[v[6]]

指定起点,起点到所有vertex的最短路径

gremlin> g.withComputer().V().has('person','name','marko').shortestPath() 
==>[v[1]]
==>[v[1],v[2]]
==>[v[1],v[4]]
==>[v[1],v[4],v[5]]
==>[v[1],v[3],v[6]]
==>[v[1],v[3]]

指定终点,所有vertex到终点最短路径

gremlin> g.withComputer().V().shortestPath().with(ShortestPath.target, __.has('name','peter')) 
==>[v[1],v[3],v[6]]
==>[v[2],v[1],v[3],v[6]]
==>[v[4],v[3],v[6]]
==>[v[3],v[6]]
==>[v[5],v[4],v[3],v[6]]
==>[v[6]]

指定起点和终点,两点间的最短路径

gremlin> g.withComputer().V().has('person','name','marko').
               shortestPath().
                 with(ShortestPath.target, __.has('name','josh')) 
==>[v[1],v[4]]

加权最短路径,通过with(ShortestPath.distance, 'weight')指定表示权重的property name

gremlin> g.withComputer().V().has('person','name','marko').
               shortestPath().
                 with(ShortestPath.target, __.has('name','josh')).
                 with(ShortestPath.distance, 'weight') 
==>[v[1],v[3],v[4]]

指定计算最短路径时,起点到终点的edge的方向

gremlin> g.withComputer().V().shortestPath().
                 with(ShortestPath.edges, Direction.IN).
                 with(ShortestPath.target, __.has('name','josh')) 
==>[v[3],v[4]]
==>[v[4]]
==>[v[5],v[4]]

返回的路径中包含edge

gremlin> g.withComputer().V().has('person','name','marko').
               shortestPath().
                 with(ShortestPath.target, __.has('name','josh')).
                 with(ShortestPath.includeEdges, true) //7\
==>[v[1],e[8][1-knows->4],v[4]]

5 tree

以树形的结构形式输出遍历过的路径。形式上类似于深度优先树

gremlin> g.V(1).out().out().tree().by('name')
==>[marko:[josh:[ripple:[],lop:[]]]]
上一篇 下一篇

猜你喜欢

热点阅读