У меня есть особая проблема, связанная с запросом над логическим полем и строковым полем, которые вложены в поле массива. Отображение индекса выглядит следующим образом:Bool query в поле массива
indexes :string_field_1, type: 'string'
indexes :string_field_2, type: 'string'
indexes :boolean_field_1, type: 'boolean'
indexes :array_field_1 do
indexes :boolean_field_2, type: 'boolean'
indexes :string_field_3, type: 'string'
end
indexes :array_field_2 do
indexes :integer_field_1, type: 'integer'
end
indexes :array_field_3 do
indexes :integer_field_2, type: 'integer'
end
Индекс документа также имеет много других полей, которые не вложены в поле массива, но должны быть включены в число полей запроса. я попробовал подход с использованием фильтра и BOOL запросов, выглядит следующим образом:
"query":
{"bool":
{"must":
[
{"query_string":
{"query":"text which is being searched",
"fields":[
"string_field_1",
"string_field_2",
"array_field_1.string_field_3"
],
"fuzziness":"1","analyze_wildcard":true,"auto_generate_phrase_queries":false,"analyzer":"brazilian","default_operator":"AND"}
}
],
"filter":[
{"bool":
{"must":
[
{"bool":
{"should":
[
{"term":{"boolean_field_1":false}},
{"terms":{"array_field_2.integer_field_1":[x,z]}},
{"term":{"array_field_3.integer_field_2":y}}]}},
{"bool":
{"should":
[
{"term":{"array_field_1.boolean_field_2":true}},
{"terms":{"array_field_2.integer_field_1":[x,z]}},
{"term":{"array_field_3.integer_field_2":y}}]}},
]
}
}
]
}
}
]
}
}
Проблема с этим запросом является то, что он возвращает документ, который, по моему мнению, не должен быть возвращен. документ, в данном случае, это ниже:
_source": {
"string_field_1": "text 1",
"string_field_2": "text 2",
"boolean_field_1": false,
"array_field_1": [
{
"boolean_field_2": true,
"string_field_3": "some text which is not being searched"
},
{
"boolean_field_2": true,
"string_field_3": "some text which is not being searched"
},
{
"boolean_field_2": false,
"string_field_3": "text which is being searched"
},
{
"boolean_field_2": true,
"string_field_3": "some text which is not being searched"
}
],
"array_field_2": [
{
"integer_field_1": A
}
],
"array_field_3": [
{
"integer_field_2": B
}
]
}
Как вы можете заметить, третий элемент array_field_1 содержит boolean_field_2: ложные, а также текст, который ищется. Но в соответствии с моим параметром filter: должны быть получены только те документы, которые array_field_1.boolean_field_2 истинны, если только array_field_2.integer_field_1: или array_field_3.integer_field_1, что неверно, согласно моей части запроса. Кажется, эластик не считает, что array_field_1 [2] является тем, что boolean_field_2 является ложным. Как я могу выполнить свой запрос, чтобы этот документ не был получен?
Спасибо это заранее, Гильерме