ElasticSearch(三):SearchAPI

一 字段类查询

字段类查询包括全文匹配和单词匹配,全文匹配针对text类型的字段进行全文检索,会对查询语句做分词,如match/match_phrase等query类型;

  • match
    针对查询语句做分词后对text字段做单词全文检索;
##通过operator参数可以控制单词间匹配关系,选项为or和and
##默认为or,查询username中包含alfred或者way的文档
GET test_search_index/_search
{
  "explain":true,
  "query": {
    "match": {
      "username": "alfred way"
    }
  }
}
##and,查询username中同时包含alfred和way的文档
GET test_search_index/_search
{
  "query": {
    "match": {
      "username": {
        "query": "alfred way",
        "operator": "and"
      }
    }
  }
}
##通过minimum_should_match控制需要匹配的单词数
GET test_search_index/_search
{
  "query": {
    "match": {
      "job": {
        "query": "java ruby engineer",
        "minimum_should_match": "3"
      }
    }
  }
}
  • match_phrase
    针对查询语句对text字段做词组的全文检索,可以通过slop控制单词间隔;
GET test_search_index/_search
{
  "query": {
    "match_phrase": {
      "job": "java engineer"
    }
  }
}
##job字段中包含java word word engineer形式
GET test_search_index/_search
{
  "query": {
    "match_phrase": {
      "job": {
        "query": "java engineer",
        "slop": "2"
      }
    }
  }
}
  • query-string
##username中同时包含alfred和way
GET test_search_index/_search
{
  "profile":true,
  "query":{
    "query_string": {
      "default_field": "username",
      "query": "alfred AND way"
    }
  }
}
##username和job字段中包含alfred或者同时包含java和ruby
GET test_search_index/_search
{
  "profile":true,
  "query": {
    "query_string": {
      "fields": [
        "username",
        "job"
      ],
      "query": "alfred OR (java AND ruby)"
    }
  }
}
  • simple-query-string
GET test_search_index/_search
{
  "profile":true,
  "query":{
    "simple_query_string": {
     "query": "alfred +way \"java",
     "fields": ["username"]
    }
  }
}

单词匹配不做分词,直接匹配字段倒排索引,如term/terms/range等query类型;

  • term/terms
    不对查询语句做分词处理;
GET test_search_index/_search
{
  "query":{
    "term":{
      "username":"alfred way"
    }
  }
}
GET test_search_index/_search
{
  "query": {
    "terms": {
      "username": [
        "alfred",
        "way"
      ]
    }
  }
}
  • range
    针对数值和日期类型做范围查询;
GET test_search_index/_search
{
  "query":{
    "range": {
      "age": {
        "gte": 10,
        "lte": 30
      }
    }
  }
}
GET test_search_index/_search
{
  "query":{
    "range": {
      "birth": {
        "gte": "now-30y"
      }
    }
  }
}

二 复合查询

复合查询是指包含字段类查询或复合查询类型;

  • constant_score query
    设置相关性得分为1或者boost值;

  • bool filter
    只过滤符合条件的文档,不会进行相关性得分;

GET test_search_index/_search
{
  "query": {
    "bool": {
      "filter": [
        {
          "term": {
            "username": "alfred"
          }
        }
      ]
    }
  }
}
  • bool must/must not
    必须或者必须不包含,影响相关性得分;
##username中必须包含alfred,job中必须包含specialist
GET test_search_index/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match": {
            "username": "alfred"
          }
        },
        {
          "match": {
            "job": "specialist"
          }
        }
      ]
    }
  }
}
  • bool 只包含should不包含must
    文档必须至少满足一个条件,minimum_should_match可以控制满足条件的个数和百分比;
GET test_search_index/_search
{
  "query": {
    "bool": {
      "should": [
        {"term": {"job": "java"}},
        {"term": {"job": "ruby"}},
        {"term": {"job": "specialist"}}
      ],
      "minimum_should_match": 2
    }
  }
}
  • bool 包含must不必满足should,满足则增加相关性得分;
GET test_search_index/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "term": {
            "username": "alfred"
          }
        }
      ],
      "should": [
        {
          "term": {
            "job": "ruby"
          }
        }
      ]
    }
  }
}
  • _count
    获取符合条件的文档数;
GET test_search_index/_count
{
  "query":{
    "match":{
      "username": "alfred"
    }
  }
}
  • _source
    过滤返回结果中_source字段;
GET test_search_index/_search
{
  "_source": ["username","age"]
}

你可能感兴趣的:(ElasticSearch(三):SearchAPI)