配列フィールドにネストされたブール フィールドと文字列フィールドのクエリに関して、非常に特殊な問題があります。インデックス マッピングは次のとおりです。
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
ドキュメント インデックスには、配列フィールドにネストされていない他の多くのフィールドもありますが、クエリ フィールドに含める必要があります。次のようなフィルターとブールクエリを使用したアプローチを試しました。
"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 の 3 番目の項目には boolean_field_2: false と検索対象のテキストが含まれています。しかし、私の filter: 句によれば、array_field_2.integer_field_1: または array_field_3.integer_field_1 が発生しない限り、array_field_1.boolean_field_2 が true であるドキュメントのみを取得する必要があります。array_field_1[2] が boolean_field_2 が false であることを考慮していないようです。このドキュメントが取得されないようにクエリを作成するにはどうすればよいですか?
よろしくお願いします、ギエルメ