2017-02-21 60 views
0

由于数据模型的结构是这样,过滤聚合存储桶密钥?

{ 
    Id: 123, 
    "string_facet": [ 
     { 
      "name": "make", 
      "value": "Audi" 
     }, 
     { 
      "name": "carListType", 
      "value": "PERSON EU" 
     }, 
     { 
      "name": "modelType", 
      "value": "" 
     }, 
     { 
      "name": "engineBrand", 
      "value": "APT" 
     }, 
     { 
      "name": "typeDescription", 
      "value": "8D2" 
     } 
    ], 
    "number_facet": [ 
     { 
      "name": "typeNumber", 
      "value": 4614 
     }, 
     { 
      "name": "serialNumber", 
      "value": 2 
     }, 
     { 
      "name": "engineSize", 
      "value": 18 
     }, 
     { 
      "name": "horsePower", 
      "value": 125 
     }, 
     { 
      "name": "kw", 
      "value": 92 
     }, 
     { 
      "name": "engineVolume", 
      "value": 1781 
     }, 
     { 
      "name": "listType", 
      "value": 0 
     } 
    ], 
    "dateTime_facet": [ 
     { 
      "name": "fromDate", 
      "value": "1999-04-01T00:00:00" 
     }, 
     { 
      "name": "toDate", 
      "value": "2000-10-01T00:00:00" 
     } 
    ]  
} 

我想聚集刻面的名称,以及每名值。但是,我只对具有特定名称的方面感兴趣,例如:使engineBrand。请注意,构面是嵌套类型的。

我已经尝试了以下.NEST表达式,但它仍然返回所有方面名称。

.Global("global", g => g 
    .Aggregations(ag => ag 
     .Filter("global_makes", f => f 
      .Filter(ff => ff 
       .Nested(n => n 
       .Path("string_facet") 
       .Filter(pf => pf.Term("string_facet.name", "make"))) 
       ) 
       .Aggregations(agg => agg 
        .Nested("nested_string_facet", nested => nested 
         .Path("string_facet") 
         .Aggregations(stringFacet => stringFacet 
          .Terms("name", nameAgg => nameAgg.Field("string_facet.name").Size(0) 
           .Aggregations(nameAggNext => nameAggNext 
            .Terms("value", valueAgg => valueAgg.Field("string_facet.value").Size(0)) 
           ) 
          ) 
         ) 
        ) 
       ) 
      ) 
     ) 
    ) 
); 

我有全球范围内的过滤器(失去的查询通过范围),然后只在符合“制造”这string_facet.name筛选,但结果还是包括所有其他名称也是如此。如何过滤聚合以包含只有桶的地方名称是“make”?

回答