Elasticsearch 查询语句概述

目录

[1. Match Query](#1. Match Query)

[2. Term Query](#2. Term Query)

[3. Terms Query](#3. Terms Query)

[4. Range Query](#4. Range Query)

[5. Bool Query](#5. Bool Query)

[6. Wildcard Query](#6. Wildcard Query)

[7. Fuzzy Query](#7. Fuzzy Query)

[8. Prefix Query](#8. Prefix Query)

[9. Aggregation Query](#9. Aggregation Query)


Elasticsearch 是一个基于 Lucene 的搜索引擎,提供了丰富的查询DSL(Domain Specific Language)用于执行搜索操作。以下是Elasticsearch中常用的查询语句类型、作用、使用场景、注意事项以及每种查询的实际例子。

1. Match Query

  • 作用:对文本进行全文搜索,包括模糊匹配。

  • 使用场景:适用于搜索文本字段。

  • 注意事项:默认情况下,对于多词搜索会采用OR操作符,可以通过operator参数修改。

  • 例子

    java 复制代码
    {
      "query": {
        "match": {
          "message": "this is a test"
        }
      }
    }

2. Term Query

  • 作用:用于精确值匹配,不会对搜索词进行分词。

  • 使用场景:适用于关键字、数字、日期等精确值字段的精确查询。

  • 注意事项:不适用于文本字段,因为文本字段会在索引时分词。

  • 例子

    java 复制代码
    {
      "query": {
        "term": {
          "status": {
            "value": "active"
          }
        }
      }
    }

3. Terms Query

  • 作用:与term query类似,但允许指定多个精确值。

  • 使用场景:当需要匹配多个精确值时使用。

  • 注意事项:与term query相同,不适用于文本字段。

  • 例子

    java 复制代码
    {
      "query": {
        "terms": {
          "status": ["active", "pending"]
        }
      }
    }

4. Range Query

  • 作用:用于查找在某个范围内的值。

  • 使用场景:适用于数字、日期等类型的范围查询。

  • 注意事项:可以使用gt、lt、gte、lte等操作符指定范围。

  • 例子

    java 复制代码
    {
      "query": {
        "range": {
          "age": {
            "gte": 10,
            "lte": 20
          }
        }
      }
    }

5. Bool Query

  • 作用:允许组合多个查询,如must、should、must_not。

  • 使用场景:当需要执行复杂的查询逻辑时使用。

  • 注意事项:should子句在没有must或filter时至少需要匹配一个条件。

  • 例子

    java 复制代码
    {
      "query": {
        "bool": {
          "must": [
            { "match": { "title": "search" } },
            { "match": { "content": "Elasticsearch" } }
          ],
          "must_not": [
            { "range": { "age": { "gte": 30 } } }
          ],
          "should": [
            { "term": { "tag": "wow" } },
            { "term": { "tag": "elasticsearch" } }
          ],
          "minimum_should_match": 1,
          "boost": 1.0
        }
      }
    }

6. Wildcard Query

  • 作用:支持使用通配符的模糊查询。

  • 使用场景:在不确定完整词项时使用。

  • 注意事项:通配符查询可能会影响性能,应谨慎使用。

  • 例子

    java 复制代码
    {
      "query": {
        "wildcard": {
          "user": {
            "value": "ki*y"
          }
        }
      }
    }

7. Fuzzy Query

  • 作用:基于Levenshtein编辑距离的模糊查询。

  • 使用场景:在处理用户输入错误的情况下很有用。

  • 注意事项:模糊查询会消耗更多的资源,应适度使用。

  • 例子

    java 复制代码
    {
      "query": {
        "fuzzy": {
          "name": {
            "value": "kiim",
            "fuzziness": 2
          }
        }
      }
    }

8. Prefix Query

  • 作用:搜索具有指定前缀的词项。

  • 使用场景:适用于自动补全功能。

  • 注意事项:与通配符查询一样,可能会影响性能。

  • 例子

    java 复制代码
    {
      "query": {
        "prefix": {
          "user": {
            "value": "ki"
          }
        }
      }
    }

9. Aggregation Query

  • 作用:用于执行复杂的数据分析和汇总。

  • 使用场景:统计分析,如计数、平均值、最大/最小值等。

  • 注意事项:聚合查询可以消耗大量资源,应合理设计。

  • 例子

    java 复制代码
    {
      "size": 0,
      "aggs": {
        "group_by_state": {
          "terms": {
            "field": "state.keyword"
          }
        }
      }
    }
相关推荐
Elasticsearch11 小时前
为上下文工程构建高效的数据库检索工具
elasticsearch
武子康12 小时前
大数据-243 离线数仓 - 实战电商核心交易增量导入(DataX - HDFS - Hive 分区
大数据·后端·apache hive
代码匠心2 天前
从零开始学Flink:Flink SQL四大Join解析
大数据·flink·flink sql·大数据处理
武子康3 天前
大数据-242 离线数仓 - DataX 实战:MySQL 全量/增量导入 HDFS + Hive 分区(离线数仓 ODS
大数据·后端·apache hive
Elasticsearch3 天前
需要知道某个同义词是否实际匹配了你的 Elasticsearch 查询吗?
elasticsearch
SelectDB4 天前
易车 × Apache Doris:构建湖仓一体新架构,加速 AI 业务融合实践
大数据·agent·mcp
武子康4 天前
大数据-241 离线数仓 - 实战:电商核心交易数据模型与 MySQL 源表设计(订单/商品/品类/店铺/支付)
大数据·后端·mysql
IvanCodes5 天前
一、消息队列理论基础与Kafka架构价值解析
大数据·后端·kafka
武子康5 天前
大数据-240 离线数仓 - 广告业务 Hive ADS 实战:DataX 将 HDFS 分区表导出到 MySQL
大数据·后端·apache hive
洛森唛6 天前
ElasticSearch查询语句Query String详解:从入门到精通
后端·elasticsearch