ElasticSearch "A" o "vacío"

0

Pregunta

Tengo el siguiente índice índice

{
  "docs": {
    "mappings": {
      "text": {
        "properties": {
          "name": {
            "type": "text",
            "fields": {
              "keyword": {
                "type": "keyword",
                "ignore_above": 256
              }
            }
          }
          "code": {
            "type": "text",
            "fields": {
              "keyword": {
                "type": "keyword",
                "ignore_above": 256
              }
            }
          }
        }
      }
    }
  }
}

"código" puede tener los valores: ["a"], ["b"],["a","b"], o []

Necesito una consulta para aliviar los valores con el código: "un" o []. Alguien puede ayudar con esta consulta, aquí es lo que he intentado hasta ahora w/out éxito (esto parece decir "a" Y "[]"; quiero "un" O "[]").

"bool": {
  "should": [
    {
      "match": {
        "code": "a"
      }
    }
  ],
  "must_not": [
    {
      "exists": {
        "field": "code"
      }
    }
  ]
}
  
elasticsearch elasticsearch-dsl
2021-11-18 20:21:18
1

Mejor respuesta

0

O se puede lograr con bool/shouldpero el bool/must restricción debe estar dentro de la bool/should.

Usted debe tratar con esta consulta:

{
  "query": {
    "bool": {
      "minimum_should_match": 1,
      "should": [
        {
          "match": {
            "code": "a"
          }
        },
        {
          "bool": {
            "must_not": [
              {
                "exists": {
                  "field": "code"
                }
              }
            ]
          }
        }
      ]
    }
  }
}
2021-11-18 21:25:31

Gracias, Esto funciona! ahh yo estaba tan cerca, tan lejos con mi consulta original
Test1 Test2

Impresionante, me alegra que funcionó!!
Val

En otros idiomas

Esta página está en otros idiomas

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