学习Gremlin - 6.查询路径path

6.查询路径path

6.1、说明

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

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

6.2、实例讲解

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

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

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

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

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

路径分为两种:有环路径和无环路径。

  • 有环路径是指路径中至少有一个对象出现的次数大于等于两次。
  • 无环路径是指路径中所有的对象只出现一次。

path()返回所有路径,包含有环路径和无环路径,例如:

// “HugeGraph”顶点到与其有两层关系的顶点的所有路径(只包含顶点)
g.V().hasLabel('software')
    .has('name','HugeGraph')
    .both()
    .both()
    .path()
6.2.2、simplePath(),过滤掉路径中含有环路的对象,只保留路径中不含有环路的对象
// “HugeGraph”顶点到与其有两层关系的顶点的不含环路的路径(只包含顶点)
g.V().hasLabel('software')
    .has('name','HugeGraph')
    .both()
    .both()
    .simplePath()
    .path()
6.2.3、cyclicPath(),过滤掉路径中不含有环路的对象,只保留路径中含有环路的对象
// “HugeGraph”顶点到与其有两层关系的顶点的包含环路的路径(只包含顶点)
g.V().hasLabel('software')
    .has('name','HugeGraph')
    .both()
    .both()
    .cyclicPath()
    .path()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值