我在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)
有人可以帮我吗
答案 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