如何在ArangoDB中检查顶点匹配

时间:2019-09-03 11:07:51

标签: arangodb graph-traversal

我在ArangoDB中创建了两个集合,一个文档集合“ Node”和一个边缘集合“ Path”。我所有的节点都有一个name属性,并通过边连接。

我的遍历具有1..10的可变深度,它将找到以下路径:

start - decide
start - decide - execute1
start - decide - execute2
start - decide - execute1 - error
start - decide - execute2 - end
start - decide - execute1 - execute2 - end
start - decide - execute1 - execute2 - error
start - decide - execute2 - execute3 - end

我尝试在下面的查询中查找以结尾或错误节点结尾的路径:

FOR v, e, p IN 1..10 OUTBOUND 'Node/start_0' Path     
OPTIONS { bfs: true}     
FILTER (v.name == "end" OR v.name == "error")     
RETURN CONCAT_SEPARATOR(' - ', p.vertices[*].name)

它给了我下面4个结果

[
    start - decide - execute1 - error
    start - decide - execute2 - end
    start - decide - execute1 - execute2 - end
    start - decide - execute1 - execute2 - error
    start - decide - execute2 - execute3 - end
] 

在这里,我想进行其他模式匹配检查,我想列出其中包含特定顶点序列的结果。

我想列出其中包含序列decide execute1 execute2的结果 即,我的结果应如下所示:

     [
     start - decide - execute1 - execute2 - end
     start - decide - execute1 - execute2 - error 
     ]

我尝试将以下过滤条件添加到查询中,但没有成功

FILTER LIKE(p.vertices[*].name, "%decide - execute1 - execute2%", true)

有人可以帮我吗

1 个答案:

答案 0 :(得分:0)

我认为,如果您将主查询移到子查询中,然后再应用过滤器,例如像这样:

FOR path IN (
    FOR v, e, p IN 1..10 OUTBOUND 'Node/start_0' Path     
    OPTIONS { bfs: true}     
    FILTER (v.name == "end" OR v.name == "error")     
    RETURN CONCAT_SEPARATOR(' - ', p.vertices[*].name)
)
FILTER LIKE(path, "%decide - execute1 - execute2%", true)
RETURN path