support Consulta de cadena de consulta Elasticsearch con no igual a?




term match elasticsearch (3)

Por lo general, con una consulta query_string en elasticsearch, puedo hacer lo siguiente:

name:"Fred"

Quiero encontrar todos los documentos donde el nombre no es igual a Fred. ¿Cuál es la sintaxis adecuada para eso? Lo intenté:

name!="Fred"

Aunque devuelve 0 documentos.


Deberías usar la consulta bool con la declaración must_not

{
  "query": {
    "bool" : {
      "must_not" : {
        "term" : {
          "name" : "Fred"
        }
      }
    }
  }
}

y, o no filtros

and:

{
    "filtered" : {
        "query" : {
            "term" : { "name.first" : "shay" }
        },
        "filter" : {
            "and" : {
                "filters" : [
                    {
                        "term" : { "name.first" : "something" }
                    },
                    {
                        "term" : { "name.first" : "other" }
                    }
                ]
            }
        }
    }
}
or:

{
    "filtered" : {
        "query" : {
            "term" : { "name.first" : "shay" }
        },
        "filter" : {
            "or" : {
                "filters" : [
                    {
                        "term" : { "name.first" : "something" }
                    },
                    {
                        "term" : { "name.first" : "other" }
                    }
                ]
            }
        }
    }
}
not:

{
    "filtered" : {
        "query" : {
            "term" : { "name.first" : "shay" }
        },
        "filter" : {
            "not" : {
                "filter" :  {
                    "term" : { "name.first" : "someting" }
                }
            }
        }
    }
}

Necesita usar el operador NOT , así:

!(name:"Fred")

o

NOT (name:"Fred")




elasticsearch