栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

Elasticsearch-查询详解

Elasticsearch-查询详解

查询详解

结果筛选查询排序分页查询过滤查询布尔值查询精确查询

term与match的比较“text”VS“keyword” 高亮查询

一般来说,我们进行搜索不是直接写条件搜索,而是需要构建一个JSON格式的请求体,这样可以设置更好的传递参数

结果筛选

j s o n 结 构 color{#0000FF}{json结构} json结构

# 查询结果筛选
GET /ceshi01/type01/_search
{
  "query": {
    "match": {
      "name": "莫迪"
    }
  },
  "_source":["name"]
}

GET /ceshi01/type01/_search
{
  "query": {
    "match": {
      "name": "莫迪"
    }
  },
  "_source":["name","age"]
}

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

查询排序

j s o n 结 构 color{#0000FF}{json结构} json结构

GET /ceshi02/_doc/_search
{
  "query": {
    "match": {
      "name": "莫迪"
    }
  },
  "sort": [
    {
    "age": {
      "order": "asc"
      }
    }
  ]
}

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

分页查询

j s o n 结 构 color{#0000FF}{json结构} json结构

# 分页查询
GET /ceshi01/type01/_search
{
  "query": {
    "match": {
      "name": "莫迪"
    }
  },
  "from": 0,
  "size": 1
}

GET /ceshi01/type01/_search
{
  "query": {
    "match": {
      "name": "莫迪"
    }
  },
  "from": 0,
  "size": 2
}

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

过滤查询

j s o n 结 构 color{#0000FF}{json结构} json结构

GET /ceshi02/_doc/_search
{
  "query": {
    "bool": {
      "must": [
        {
          "match": {
            "name": "莫迪"
          }
        }
      ],
      "filter": {
        "range": {
          "age": {
            "lt": 20
          }
        }
      }
    }
  }
}

参 数 解 析 color{#00FFFF}{参数解析} 参数解析

gtgteltlte
大于大于等于小于小于等于

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

布尔值查询

j s o n 结 构 color{#0000FF}{json结构} json结构

GET ceshi01/type01/_search
{
  "query": {
    "bool": {
      "should": [
        {
          "match": {
          "name": "莫迪"
          }
        },
        {
          "match": {
            "name": "瑞克"
          }
        }
      ]
    }
  }
}

参 数 解 析 color{#00FFFF}{参数解析} 参数解析

mustmust notshould
设置的所有match都要匹配才会返回结果返回和结果相反的结果满足条件之一就可以返回结果

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

精确查询

j s o n 结 构 color{#0000FF}{json结构} json结构

# 精确查询
GET ceshi01/type01/_search
{
  "query": {
    "bool": {
      "should": [
        {
          "term": {
          "name.keyword": "莫迪"
          }
        }
      ]
    }
  }
}

参 数 解 析 color{#00FFFF}{参数解析} 参数解析

term查询是使用倒排索引进行精确查询

term与match的比较

term使用倒排索引直接进行精确查询match则会使用分词器进行解析后再查询,说白了就是先分析文档然后通过分析结果进行查询 “text”VS“keyword”

textkeyword
text会使用分词器进行分词后再查询keyword不会使用分词器进行分词,直接查询

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

高亮查询

j s o n 结 构 color{#0000FF}{json结构} json结构

# 高亮查询
GET /ceshi01/type01/_search
{
  "query": {
    "match": {
      "name": "莫迪"
    }
  },
  "highlight": {
    "pre_tags": "

", "post_tags": "

", "fields": { "name":{ } } } }

运 行 结 果 color{#FF00FF}{运行结果} 运行结果

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/720060.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号