задний план
Недавно возникла проблема с онлайн-запросом 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 amust
orfilter
clause then a document will match thebool
query even if none of theshould
queries match. In this case these clauses are only used to influence the score. If thebool
query is a filter context or has neithermust
orfilter
then at least one of theshould
queries must match a document for it to match thebool
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
Возьмите пересечение всех данных:
- Переместите условие запроса в
filter
в контексте - использовать настройки
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/…