Сводка логического запроса Elasticsearch

Elasticsearch
задний план

Недавно возникла проблема с онлайн-запросом es, и, наконец, решили использоватьbool queryПоявляется, когда в запросе объединено несколько условий.shouldЗапрос предложения завершается неудачей, поэтому ищите данные, чтобы определить проблему.

вElasticsearch: 5.5.0

проблема

Найти связанные запросы:

"query": {
    "bool": {     // bool query 查询
      "should": [ // should子句
        {
          "match_phrase": {
            "name": {
              "query": "星起",
              "boost": 30,
              "slop": 5
            }
          }
        }
      ],
      "filter": { // #filter子句
        "bool": {
          "must": [
            {
              "terms": {
                "round": ["A轮"]
              }
            },
          ]
        }
      }
    }
  }

Проблема в следующем: использоватьbool queryПри объединении запросовshouldиfilterРезультат комбинированного запроса соответствует толькоfilterоговорка, не соответствуетshouldоговорка, не могу добратьсяshouldиfilterВозьмите ожидаемый перекресток.

Решение

Полистайте официальную документацию:Bool Query | Elasticsearch Reference [5.5] | Elasticправильноshouldобъяснение:

The clause (query) should appear in the matching document. If the bool query is in a query context and has a must or filter clause then a document will match the bool query even if none of the should queries match. In this case these clauses are only used to influence the score. If thebool query is a filter context or has neither must or filter then at least one of the should queries must match a document for it to match the bool query. This behavior may be explicitly controlled by settings the minimum_should_match parameter.

В основном это означает:shouldпредложение используется в соответствующих документах, еслиboolзапрос находится вqueryконтекст, и естьmustилиfilterпунктshouldСоответствует ли запрос или нет, не имеет значенияmustилиfilterпункт запроса. Эти пункты влияют только на запросscoreВот и все. еслиboolзапрос находится вfilterконтекст или ни то, ни другоеmustниfilterдолжен быть хотя бы одинshouldзапрос должен соответствоватьboolЗапрос. Также можно явно указатьminimum_should_matchэтот параметр для решения. Как видно из официальной документации, есть 2 способаbool queryВозьмите пересечение всех данных:

  1. Переместите условие запроса вfilterв контексте
  2. использовать настройкиminimum_should_matchпараметр
решение

С помощью двух упомянутых выше методов давайте попробуем посмотреть, сможем ли мы достичь ожидаемой цели.

Вариант первый

использоватьfilterКонтекст:

"query": {
    "bool": {
      "filter": { // filter上下文
        "bool": {
          "should": [ // should子句
            {
              "match_phrase": {
                "name": {
                  "query": "星起",
                  "boost": 30,
                  "slop": 5
                }
              }
            }
          ],
          "filter": { // filter子句
            "bool": {
              "must": [
                {
                  "terms": {
                    "round": ["A轮"]
                  }
                }
              ]
            }
          }
        }
      }
    }
  }

Результаты теста следующие:

"hits": {
    "total": 1,
    "max_score": null,
    "hits": [
      {
        "_index": "index_name",
        "_type": "hub/product",
        "_id": "id",
        "_score": 0.0, // filter下分值为0.0
        "_source": {
          "round": "A轮",
          "name": "星起Starup",
          "created_at": "2015-12-25T22:20:36.210+08:00",
          "sector_name": "企业服务"
        },
        "highlight": {
          "name": ["<em>星起</em>Starup"]
        },
        "sort": []
      }
    ]
  }

Результаты испытаний удовлетворяютshouldиfilterПункт пересечения, следует отметить, что оценка результата0.0, без оценки степени совпадения результата запроса.

Вариант 2

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

"query": {
    "bool": {     
      "should": [ // should 子句
        {
          "match_phrase": {
            "name": {
              "query": "星起",
              "boost": 30,
              "slop": 5
            }
          }
        }
      ],
      "minimum_should_match": 1, // 最少匹配一项should中条件子句
      "filter": { // filter子句
        "bool": {
          "must": [
            {
              "terms": {
                "round": ["A轮"]
              }
            },
          ]
        }
      }
    }
  }

Результаты теста следующие:

"hits": {
    "total": 1,
    "max_score": null,
    "hits": [
      {
        "_index": "index_name",
        "_type": "hub/product",
        "_id": "id",
        "_score": 757.66394,
        "_source": {
          "round": "A轮",
          "name": "星起Starup",
          "created_at": "2015-12-25T22:20:36.210+08:00",
          "sector_name": "企业服务"
        },
        "highlight": {
          "name": ["<em>星起</em>Starup"]
        },
        "sort": [757.66394]
      }
    ]
  }

ДанныеshouldиfilterПересечение пунктов, которые соответствуют ожидаемому результату и имеют соответствующую оценку совпадения.

Суммировать

Как видно из двух приведенных выше решений,ElasticsearchОн относительно гибок в плане запроса, обычно помимо знакомства с официальными документами необходимо совместить потребности бизнеса, чтобы найти правильное решение проблемы.

Перепечатано с:blog.lovecoding.org/2018/12/18/…

Ссылаться на
  1. Bool Query | Elasticsearch Reference [5.5] | Elastic
  2. Boolean Operations and Filters in the Bool Query in Elasticsearch | Elastic
  3. Эластичный поисковый запрос