如何检查 ArangoDB 中的顶点匹配

How to check for Vertex Matching in ArangoDB

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

我的遍历的变量深度为 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)

谁能帮我解决这个问题

我相信如果您将主查询移动到子查询中,然后再应用过滤器,例如类似于:

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