2017-02-21 10 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»?

ответ