bounty将在23小时后过期。回答此问题可获得+50的信誉奖励。Vladimir Djukic正在寻找来自信誉良好来源的答案:我需要的代码,将解决这2个问题,我提到的问题:
- 只过滤以所需元素结束的路径-每个路径都需要分开
以下是我正在处理的集合:
- sign1: A1
- sign2: A2
- sign1: A2
- sign2: A5
- sign1: A2
- sign2: A6
- sign1: A2
- sign2: A8
- sign1: A5
- sign2: A8
查询应查找从A1到A8的路径
例如,它应查明:
path1:
A1 A2 -> A2 A5 -> A5 A8
path2:
A1 A2 -> A2 A8
path3:
A1 A2 -> A2 A6 -> should be ignored since not finishes with A8
目前,我尝试了这个(部分解决方案由@ray):
My Query
我的查询的第一个问题是,即使不是以A8结尾,它也会返回所有路径
第二个问题是不分隔路径会将所有内容放在一个数组中
1条答案
按热度按时间ghhaqwfi1#
要过滤并仅返回以
A8
结尾的路径,您必须在$graphLookup
之后再次使用$match stage**。您可以尝试类似这样的操作,仅返回以
A8
结尾的路径现在,如果您想将路径分隔到不同的数组/文档中,则必须在
$match
阶段之前使用$unwind stage,如下所示:EDITED:如果您想过滤掉不需要的路径或
step
等于0的路径,您可以在$graphLookup
阶段使用$filter
操作,如下所示,根据这两个条件返回结果。型