Как использовать вложенное поле в скрипте фильтра Elasticsearch - PullRequest
1 голос
/ 09 января 2020

У меня есть следующие сопоставления:

 "properties": {
      "created": {
        "type": "date"
      },
      "id": {
        "type": "keyword"
      },
      "identifier": {
        "type": "keyword"
      },
      "values": {
          "properties": {
            "description_created-date": {
              "properties": {
                "<all_channels>": {
                  "properties": {
                    "<all_locales>": {
                      "type": "date"
                    }
                  }
                }
              }
            },
            "footwear_size-option": {
              "properties": {
                "<all_channels>": {
                  "properties": {
                    "<all_locales>": {
                      "type": "keyword"
                    }
                  }
                }
              }
            }
          }
        }
      }

Теперь я хотел бы создать запрос на основе поля description_created-date и использовать это значение в безболезненном сценарии, сравнивая его с какой-либо датой.

GET index/pim_catalog_product/_search
{
  "query": {
    "constant_score": {
      "filter": {
        "bool": {
          "filter": [
            {
              "script": {
                "script": {
                  "source": "doc['values']['description_created-date']['<all_channels>']['<all_locales>'].value == '2019-12-19'",
                  "lang": "painless"
                }
              }
            }
          ]
        }
      }
    }
  }
}

Но я получаю следующую ошибку:

{
  "shard": 0,
  "index": "index",
  "node": "cmh1RMS1SHO92SA3jPAkJA",
  "reason": {
    "type": "script_exception",
    "reason": "runtime error",
    "script_stack": [
      "org.elasticsearch.search.lookup.LeafDocLookup.get(LeafDocLookup.java:81)",
      "org.elasticsearch.search.lookup.LeafDocLookup.get(LeafDocLookup.java:39)",
      "doc['values']['description_created-date']['<all_channels>']['<all_locales>'].value == '2019-12-19'",
      "    ^---- HERE"
    ],
    "script": "doc['values']['description_created-date']['<all_channels>']['<all_locales>'].value == '2019-12-19'",
    "lang": "painless",
    "caused_by": {
      "type": "illegal_argument_exception",
      "reason": "No field found for [values] in mapping with types [pim_catalog_product]"
    }
  }
}

(я знаю, что не могу сравнить даты, подобные этой, но это другая проблема).

Поиск по values.description_created-date поле работает :

GET index/pim_catalog_product/_search
{
  "query": {
    "match": {
      "values.description_created-date.<all_channels>.<all_locales>": "2019-12-19"
    }
  }
}

И когда я получаю указанный c документ, значение этого поля представляется так:

"values": {
  "description_created-date": {
    "<all_channels>": {
      "<all_locales>": "2019-12-19"
    }
  }
}

Как я могу использовать это поле в фильтре сценариев? Мне нужно это, чтобы выполнить что-то вроде этого:

(pseudocode)
"source": "doc['values']['stocks_created-date'].value > doc['created'].value + 2 days"

Я использую elasicsearch v6.5.0, вот docker -композитный файл сasticsearch и kibana:

version: '3'
services:
  elasticsearch:
    image: docker.elastic.co/elasticsearch/elasticsearch:6.5.0
    environment:
      - discovery.type=single-node
    ports:
      - 9200:9200
  kibana:
    image: docker.elastic.co/kibana/kibana:6.5.0
    ports:
      - 5601:5601

и суть с полными сопоставлениями и примерами данных здесь

Спасибо.

1 Ответ

0 голосов
/ 11 января 2020

Спасибо за расширенные отображения! При вызове поля во вложенном объекте попробуйте ссылаться на внутреннее поле, используя точечную запись. Пример:

"source": "doc['values.description_created.<all_channels>.<all_locales>'].value == 2019"

Кроме того, вы можете сократить ваши составные запросы только до основного constant_score составного запроса. Пример:

GET index/_search
{
  "query": {
    "constant_score": {
      "filter": {
        "script": {
          "script": {
            "source": "doc['values.description_created.<all_channels>.<all_locales>'].value == 2019"
          }
        }  
      },
      "boost": 1
    }
  }
}

ПРИМЕЧАНИЕ. Значение «boost» не является обязательным, но оно используется по умолчанию, если вы не указали значение «boost».

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