Dotaz s NEBO/A uvnitř NEBO/A stav s Elasticsearch 7.x

0

Otázka

Potřebujete Pomoci.

Jak to udělat Query do Elasticsearch, jako je tento:

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'

Děkuji.

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

Nejlepší odpověď

0

Můžete použít bool dotaz

  1. musí/filtr klauzule ... funguje to jako "A". musí vypočítá skóre a filtr
    pouze vybere dokumenty.
  2. by klauzule - line NEBO funguje
{
  "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

Poznámka: měli Byste se raději filter místo must když děláte přesná shoda dotazy
Val

V jiných jazycích

Tato stránka je v jiných jazycích

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