ES(elasticsearch) query DSL 查询语法

全文检索,入参分词后检索整个文档

"query_string": {
    "default_field": "name",
    "query": "被检索的字符串"
}

前缀检索,入参分词
"prefix":{
   "name": "被检索的前缀"
}

按属性精确查找,入参不会被分词
"term": {
    "name": "被检索的字符串"
}

按属性多值精确查找,入参不会被分词

"terms": {
    "name": [
        "被检索的字符串1",
        "被检索的字符串2"
    ]
}

多属性分词查找,入参被分词

"multi_match": {
    "query": "被检索的字符串",
    "fields": [
        "name",
        "city"
    ]
}

按属性分词查找,入参被分词

"match": {
    "name": "name 是字段名,这段话是要检索的文本"
}

短语查找,入参分词,但是词序不变

"match_phrase": {
    "name": "完整匹配"
}

范围查找 

"range": { "age": { "gte": 10, "lte": 20 } } bool 值查找很特殊,它是上面查找的组合,可以把他们理解为 逻辑连接,上面的查询都是对文档的过滤。 filter 关键字也是
过滤作用的,但是它不能单独使用,必须跟 bool 联合使用
"bool": { "must_not": [ { "term": { "name": { "value": "被检索的字符串" } } } ], "filter": { "exists": { "field": "被检查的字段名" } } }

 

posted on 2020-06-25 17:04  一直小飞猫  阅读(2002)  评论(0编辑  收藏  举报

导航