Zapytanie LUB/I wewnątrz LUB/I warunek z pomocą Elasticsearch 7.x

0

Pytanie

potrzebuje pomocy.

Jak wykonać zapytanie w Elasticsearch w następujący sposób:

SELECT * FROM  tableA WHERE 
tableA.clm1 IN ('A','B') 
AND 
(tableA.clm2 IN ('C', 'D') OR tableA.clm3 IN ('E','F'))
OR 
tableA.clm4 = 'Z'

Dziękuję.

elasticsearch
2021-11-19 01:02:37
1

Najlepsza odpowiedź

0

Można użyć zapytania bool

  1. oferta must/filter -- działa jak "I". musi obliczać punkty i filtrowanie
    tylko wybiera dokumenty.
  2. czy oferta - działa wiersz LUB
{
  "query": {
    "bool": {
      "should": [  
        {
          "term": {
            "clm4.keyword": {
              "value": "Z"
            }
          }
        },  -- OR
        {
          "bool": {
            "filter": [
              {
                "terms": {
                  "clm1.keyword": [
                    "A",
                    "B"
                  ]
                }
              },  --AND
              {
                "bool": {
                  "should": [
                    {
                      "terms": {
                        "clm2.keyword": [
                          "C",
                          "D"
                        ]
                      }
                    }, --OR
                    {
                      "terms": {
                        "clm3.keyword": [
                          "E",
                          "F"
                        ]
                      }
                    }
                  ]
                }
              }
            ]
          }
        }
      ]
    }
  }
}
2021-11-19 07:01:02

Uwaga na boku: musisz wybrać filter zamiast must podczas wykonywania zapytań dokładnego dopasowania
Val

W innych językach

Ta strona jest w innych językach

Русский
..................................................................................................................
Italiano
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................