Подтвердить что ты не робот

Elasticsearch не сортирует результаты

У меня проблема с запросом elasticsearch. Я хочу иметь возможность сортировать результаты, но elasticsearch игнорирует тег сортировки. Здесь мой запрос:

{
    "sort": [{
        "title": {"order": "desc"}
    }],
    "query":{
        "term": { "title": "pagos" }
    }
}

Однако, когда я удаляю часть запроса и отправляю только тег сортировки, он работает. Может ли кто-нибудь указать мне правильный путь?

Я также попробовал следующий запрос: полный запрос, который у меня есть:

{
  "sort": [{
    "title": {"order": "asc"}
  }],
  "query":{
    "bool":{
      "should":[
        {
          "match":{
            "title":{
              "query":"Pagos",
              "boost":9
            }
          }
        },
        {
          "match":{
            "description":{
              "query":"Pagos",
              "boost":5
            }
          }
        },
        {
          "match":{
            "keywords":{
              "query":"Pagos",
              "boost":3
            }
          }
        },
        {
          "match":{
            "owner":{
              "query":"Pagos",
              "boost":2
            }
          }
        }
      ]
    }
  }
}

Настройки

{
  "settings": {
    "analysis": {
      "filter": {
        "autocomplete_filter": {
          "type": "ngram",
          "min_gram": 3,
          "max_gram": 15,
          "token_chars": [
            "letter",
            "digit",
            "punctuation",
            "symbol"
          ]
        }
      },
      "analyzer": {
        "default" : {
          "tokenizer" : "standard",
          "filter" : ["standard", "lowercase", "asciifolding"]
        },
        "autocomplete": {
          "type": "custom",
          "tokenizer": "standard",
          "filter": [
            "lowercase",
            "asciifolding",
            "autocomplete_filter"
          ]
        }
      }
    }
  }
}

<сильного > Отображение

{
  "objects": {
    "properties": {
      "id":             { "type": "string", "index": "not_analyzed" },
      "type":           { "type": "string" },
      "title":          { "type": "string", "boost": 9, "analyzer": "autocomplete", "search_analyzer": "standard" },
      "owner":          { "type": "string", "boost": 2 },
      "description":    { "type": "string", "boost": 4 },
      "keywords":       { "type": "string", "boost": 1 }
    }
  }
}

Спасибо заранее!

4b9b3361

Ответ 1

Поле "title" в вашем документе является анализируемым строковым полем, которое также является многозначным полем, что означает, чтоasticsearch разделит содержимое поля на токены и сохранит его отдельно в индексе. Возможно, вы захотите отсортировать поле "заголовок" в алфавитном порядке по первому члену, затем по второму слагаемому и т.д., Но у эластичного поиска нет этой информации во время сортировки.

Следовательно, вы можете изменить свое отображение поля "title" из:

{
  "title": {
    "type": "string", "boost": 9, "analyzer": "autocomplete", "search_analyzer": "standard"
  }
}

в многопрофильное отображение, как это:

{
  "title": {
    "type": "string", "boost": 9, "analyzer": "autocomplete", "search_analyzer":"standard",
    "fields": {
      "raw": {
        "type": "string",
        "index": "not_analyzed"
      }
    }
  }
}

Теперь выполните поиск на основе проанализированного поля "title" и выполните сортировку на основе поля not.analyzed "title.raw".

{
    "sort": [{
        "title.raw": {"order": "desc"}
    }],
    "query":{
        "term": { "title": "pagos" }
    }
}

Здесь прекрасно объясняется: сортировка строк и мультиполя