第5期 Gremlin Steps:

path()、simplePath()、cyclicPath()

本系列文章的Gremlin示例均在HugeGraph图数据库上执行,环境搭建可参考准备Gremlin执行环境,本文示例均以其中的“TinkerPop关系图”为初始数据。

chemkin算例文件在哪_图查询语言

上一期:深入学习Gremlin(4):图查询返回结果数限制

Path说明

在使用Gremlin对图进行分析时,关注点有时并不仅仅在最终达到顶点、边或者属性,通过什么样的路径到达最终的顶点、边和属性同样重要。此时可以借助path()来获取经过的路径信息。

path()返回当前遍历过的所有路径。有时需要对路径进行过滤,只选择没有环路的路径或者选择包含环路的路径,Gremlin针对这种需求提供了两种过滤路径的step:simplePath()和cyclicPath()。

实例讲解1. path(),获取当前遍历过的所有路径
// “HugeGraph”顶点到与其有直接关联的顶点的路径(仅包含顶点)
g.V().hasLabel('software').has('name','HugeGraph').both().path()

1

2

chemkin算例文件在哪_Gremlin_02

如果想要同时获得经过的边的信息,可以用.bothE().otherV()替换both()

// “HugeGraph”顶点到与其有直接关联的顶点的路径(包含顶点和边)
g.V().hasLabel('software').has('name','HugeGraph').bothE().otherV().path()
  • 1
  • 2

chemkin算例文件在哪_Gremlin_03

输出路径的时候,可以通过by()语句指定使用对象的某个属性代替对象,且by()列表是循环应用到路径中的对象,例如路径有3个对象[A B C],by()语句指定两个属性[X Y],代表用“用A的X属性代表A,用B的Y属性代表B,用C的X属性代表C”,具体可参考如下例子:

by()语句的用法详解可以参见TinkerPop By Step

// “HugeGraph”顶点到与其有直接关联的顶点的路径(包含顶点和边)
// 用“name”属性代表person和software顶点,用“weight”属性代表边
g.V().hasLabel('software').has('name','HugeGraph').bothE().otherV().path().by('name').by('weight')
  • 1
  • 2
  • 3

chemkin算例文件在哪_HugeGraph_04

path()返回所有路径,不论是否含有环路,例如:

// “HugeGraph”顶点到与其有两层关系的顶点的所有路径(只包含顶点)
g.V().hasLabel('software').has('name','HugeGraph').both().both().path()
  • 1
  • 2

chemkin算例文件在哪_图查询语言_05

图中红框内的是含有环路的路径,其他的是不含有环路的路径

2. simplePath(),过滤掉路径中含有环路的对象,只保留路径中不含有环路的对象
// “HugeGraph”顶点到与其有两层关系的顶点的不含环路的路径(只包含顶点)
g.V().hasLabel('software').has('name','HugeGraph').both().both().simplePath().path()
  • 1
  • 2

chemkin算例文件在哪_HugeGraph_06

3. cyclicPath(),过滤掉路径中不含有环路的对象,只保留路径中含有环路的对象
// “HugeGraph”顶点到与其有两层关系的顶点的包含环路的路径(只包含顶点)
g.V().hasLabel('software').has('name','HugeGraph').both().both().cyclicPath().path()
  • 1
  • 2

chemkin算例文件在哪_Gremlin_07