Как добавить поля сообщения на основе результата упругого поиска - PullRequest
0 голосов
/ 27 декабря 2018

На самом деле я хочу добавить поле «is_promoted» в ответ в соответствии с результатом упругого поиска, если «doc_count» равно 1, тогда я должен получить идентификатор свойства и флаг «is_promoted» из фактического результата (которыйВы можете видеть на вопрос). Это как пост-фильтр в упругом поиске.но я хочу добавить условие в пост-фильтр.пожалуйста, смотрите текущий и ожидаемый результат.И ниже текущий вывод эластичного запроса

 {
    "total_records": 32392,
    "fetched_records": 3845,
    "result": [
        {
            "key": "dp3w",
            "doc_count": 343,
            "centroid": {
                "location": {
                    "lat": 41.919059987131064,
                    "lon": -87.71653202438385
                },
                "count": 343
            }
        },
        {
            "key": "djvw",
            "doc_count": 1,
            "centroid": {
                "location": {
                    "lat": 33.49416188221888,
                    "lon": -82.0443208285174
                },
                "count": 1
            }
        },
        {
            "key": "9qhs",
            "doc_count": 1,
            "centroid": {
                "location": {
                    "lat": 34.52696419113244,
                    "lon": -117.29711956000672
                },
                "count": 1
            }
        }
] 
}

Поэтому я хочу добавить поле "is_promoted", если "doc_count" равно 1, а ниже - ожидаемый вывод

 {
    "total_records": 32392,
    "fetched_records": 3845,
    "result": [
        {
            "key": "dp3w",
            "doc_count": 343,
            "centroid": {
                "location": {
                    "lat": 41.919059987131064,
                    "lon": -87.71653202438385
                },
                "count": 343
            }
        },
        {
            "key": "djvw",
            "doc_count": 1,
            "is_promoted":true,
            "centroid": {
                "location": {
                    "lat": 33.49416188221888,
                    "lon": -82.0443208285174
                },
                "count": 1
            }
        },
        {
            "key": "9qhs",
            "doc_count": 1,
            "is_promoted":true,
            "centroid": {
                "location": {
                    "lat": 34.52696419113244,
                    "lon": -117.29711956000672
                },
                "count": 1
            }
        }
] 
}

Для этого я использовал агрегацию.

                    query.bool.minimum_should_match = 1;
                aggQuery.zoomedin = {
                    filter: {
                        geo_bounding_box: {
                            location: {
                                top_left: {
                                    lat: params.geo_bounding_box.location.nw.lat,
                                    lon: params.geo_bounding_box.location.nw.lng
                                },
                                bottom_right: {
                                    lat: params.geo_bounding_box.location.se.lat,
                                    lon: params.geo_bounding_box.location.se.lng
                                }
                            }
                        }
                    },
                    aggregations: {
                        result: {
                            geohash_grid: {
                                field: "location",
                                precision: zoomLevel
                            },
                            "aggs": {
                                "centroid": {
                                    "geo_centroid": { "field": "location" }
                                }
                            }
                        }
                    }

Ниже приведена структура записей в моем упругом поиске.Я надеюсь, что это поможет вам понять senario

"hits": {
"total": 7967,
"max_score": 1,
"hits": [
  {
    "_index": "biproxi-test",
    "_type": "listings",
    "_id": "5126",
    "_score": 1,
    "_source": {
      "address_line1": "Brandon Town Center Drive",
      "address_line2": "USA",
      "building_class": null,
      "building_type": null,
      "built_year": null,
      "cap_rate": null,
      "category": 1,
      "city": "Brandon",
      "country": "United States",
      "county": "Hillsborough",
      "floor_location": null,
      "inplace_occupancy": null,
      "land_size": 3,
      "lease_type_id": null,
      "lease_type": null,
      "listing_group": "Retail",
      "listing_type": [
        1
      ],
      "location": {
        "lat": 27.937159,
        "lon": -82.327498
      },
      "no_of_units": null,
      "postal_code": "33511",
      "price": 2185000,
      "renovated_year": null,
      "square_feet": null,
      "state": "Florida",
      "state_code": "FL",
      "title": "3+- Acres at Brandon Town Center",
      "status": 2,
      "listing_image": "https://biproxi.s3.amazonaws.com/image/listing/5126/caf39154-fb42-483f-9320-9e9c394be66b.jpg",
      "seller_id": "113157245308689129523",
      "is_promoted": false
    }
  },      {
    "_index": "biproxi-test",
    "_type": "listings",
    "_id": "5213",
    "_score": 1,
    "_source": {
      "address_line1": "1909 N. Columbia Street",
      "address_line2": "USA",
      "building_class": null,
      "building_type": null,
      "built_year": "1996",
      "cap_rate": null,
      "category": 2,
      "city": "Milledgeville",
      "country": "United States",
      "county": "Baldwin",
      "floor_location": null,
      "inplace_occupancy": null,
      "land_size": null,
      "lease_type_id": null,
      "lease_type": null,
      "listing_group": "Retail",
      "listing_type": [
        1
      ],
      "location": {
        "lat": 33.1086,
        "lon": -83.25388
      },
      "no_of_units": null,
      "postal_code": "31061",
      "price": null,
      "renovated_year": null,
      "square_feet": null,
      "state": "Georgia",
      "state_code": "GA",
      "title": "Milledge Village - 1 Space Remaining",
      "status": 2,
      "listing_image": "https://biproxi.s3.amazonaws.com/image/listing/5213/33d1cd5b-11a1-427d-8948-2e2db3d8e7f2.jpg",
      "seller_id": "113157245308689129523",
      "is_promoted": false
    }
  }
}]}

1 Ответ

0 голосов
/ 27 декабря 2018

Итак, из обсуждения в прямых комментариях под вашим OP я понимаю, что вы хотите добавить поле is_promoted только к некоторым объектам в массиве result ответа ES, согласно определенному условию.

То, что вам нужно сделать, очень просто: перебрать массив result, проверить условие для каждого объекта и добавить свойство.

for (const obj of elasticSearchResult.result) {
    if (+obj.doc_count <= 1) {
      obj['is_promoted'] = true;
    }
  }

Я добавлю +поставить знак перед obj.doc_count, чтобы убедиться, что он проанализирован до int и, таким образом, провести надлежащее условное сравнение.Свойство is_promoted добавляется в качестве ключа массива, чтобы гарантировать отсутствие ошибок компиляции или времени выполнения типа Property does not exist, поскольку мы создаем новое свойство в объекте.

Я не знаю, почемуВы используете эту функцию агрегации.Ваша проблема связана исключительно с JavaScript и не имеет ничего общего с ES или Node.js, в частности.

PS Это решение основано на том факте, что я правильно понимаю ваш вопрос.В противном случае, пожалуйста, расширьте или улучшите ваш OP.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...