2016-08-08 9 views
0

У меня есть особая проблема, связанная с запросом над логическим полем и строковым полем, которые вложены в поле массива. Отображение индекса выглядит следующим образом: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 является ложным. Как я могу выполнить свой запрос, чтобы этот документ не был получен?

Спасибо это заранее, Гильерме

ответ

0

Другой подход состоит в помещении запроса array_field_1.string_field_3 вместе с BOOL запроса, связанного с булевой поле:

"query":{ 
    "bool":{ 
     "should": 
     [ 
      { 
       "query_string": 
        { 
         "query":"text which is being searched", 
         "fields": 
          [ 
           "string_field_1", 
           "string_field_2" 
          ], 
          "fuzziness":"1","analyze_wildcard":true,"auto_generate_phrase_queries":false,"analyzer":"brazilian","default_operator":"AND" 
        } 
      }, 
      { 
       "bool":{ 
        "must": 
        [ 
         { 
          "query_string": 
          { 
           "query":"text which is being searched", 
           "fields":["array_field_1.string_field_3"], 
           "fuzziness":"1","analyze_wildcard":true,"auto_generate_phrase_queries":false,"analyzer":"brazilian","default_operator":"AND" 
          } 
         }, 
         { 
          "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}} 
           ] 
          } 
         } 
        ] 
       } 
      } 
     ], 
     "filter": 
     [ 
      { 
       "bool":{ 
        "should": 
        [ 
         {"term":{"boolean_field_1":false}}, 
         {"terms":{"array_field_2.integer_field_1":[x,z]}}, 
         {"term":{"array_field_3.integer_field_2":y}} 
        ] 
       } 
      } 
     ] 
    } 
} 

Этот запрос также получающего документ, к сожалению, , Я действительно не знаю, как правильно построить этот запрос.

Запрос выше организована как: (х) или (А и (В или С или D))

0

Это было мое решение:

"query":{ 
    "bool":{ 
     "should": 
     [ 
      { 
       "query_string": 
        { 
         "query":"text which is being searched", 
         "fields": 
          [ 
           "string_field_1", 
                 "string_field_2" 
          ], 
          "fuzziness":"1","analyze_wildcard":true,"auto_generate_phrase_queries":false,"analyzer":"brazilian","default_operator":"AND" 
        } 
      }, 
      { 
       bool: { 
            should:[ 
             { 
              query:{ 
               nested: { 
                path: 'array_field_1', 
                query: { 
                 bool: { 
                  must: [ 
                   { match: { "array_field_1.string_field_3": "text which is being searched"} }, 
                   {term: {"array_field_1.boolean_field_2": true}} 
                  ] 
                 } 
                } 
               } 
              } 
             }, 
             { 
              bool: 
              { 
              must: [ 
              { 
                query:{ 
                 nested: { 
                  path: 'movimentos', 
                  query: { 
                   bool: { 
                    must: [ 
                     { match: { "array_field_1.string_field_3": "text which is being searched"} }, 
                     {term: {"array_field_1.boolean_field_2": false 
                    ] 
                   } 
                  } 
                 } 
                } 
               }, 
               { 
                query: { 
                bool: { 
                  should: [ 
                   {"terms":{"array_field_2.integer_field_1":[x,z]}}, 
                   {"term":{"array_field_3.integer_field_2":y}} 
                  ] 
                 } 
                 } 
               } 
               ] 
              } 
             } 
            ] 
           } 
     } 
    ] 
    } 
}