gpt4 book ai didi

graph - 从遍历中选择路径并过滤目标顶点(OrientDB)

转载 作者:行者123 更新时间:2023-12-05 05:25:22 24 4
gpt4 key购买 nike

我是图形数据库和 OrientDB 的新手,感谢您的耐心等待。

我有以下 SQL 查询来为两个顶点之间的最短路径生成一组扩展结果(我正在使用 GratefulDeadConcerts 数据库):

select expand(sp) from (select shortestPath(#9:2,#9:15,'BOTH') as sp)

无论出于何种原因,使用不带别名的扩展不会产生任何结果,但这并不是真正的问题。

我要的不是最短路径,而是可能路径和分支的集合。

我试过使用 travesedVertex:

SELECT traversedVertex(-1) FROM ( TRAVERSE out() FROM #9:2 WHILE $depth <= 10 )

但我不知道如何设置目的地,或者(老实说)如何解释我得到的结果。

编辑如果从 A 到 B 有多种方式,我希望每条路径都作为一个集合返回,例如:

{
paths: [
[#9:2, #4:16, #8:7, #9:15],
[#9:2, #4:2, #16:5, #11:3, #9:15],
[#9:2, #4:4, #11:6, #9:15]
]
}

感谢您的帮助。

最佳答案

首先,$path 是当前路径的字符串表示。其次,您可以在外部查询的 where 子句上过滤目标列。试试这个:

SELECT 
$path
FROM
( TRAVERSE
out()
FROM
#9:2
WHILE
$depth <= 10 )
WHERE
@rid = #9:15

我得到以下输出: query result

这是您要找的吗?

如果我不添加 where 子句,我会得到以下输出: query result without where

关于graph - 从遍历中选择路径并过滤目标顶点(OrientDB),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31661861/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com