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"
          }
        }
      }
    }
相关推荐
Jackyzhe8 小时前
Flink源码阅读:Netty通信
大数据·flink
反向跟单策略8 小时前
期货反向跟单—高频换人能够提高跟单效率?
大数据·人工智能·学习·数据分析·区块链
Java 码农8 小时前
RabbitMQ集群部署方案及配置指南08--电商业务延迟队列定制化方案
大数据·分布式·rabbitmq
艾莉丝努力练剑8 小时前
【优选算法必刷100题:专题五】(位运算算法)第033~38题:判断字符是否唯一、丢失的数字、两整数之和、只出现一次的数字 II、消失的两个数字
java·大数据·运维·c++·人工智能·算法·位运算
奇树谦8 小时前
FastDDS阿里云DDSRouter安装和使用(失败)
elasticsearch·阿里云·云计算
渡我白衣8 小时前
计算机组成原理(14):算术逻辑单元ALU
大数据·人工智能·算法·机器学习·计组·数电·alu
色空大师8 小时前
服务打包包名设置
java·elasticsearch·maven·打包
TOPGUS9 小时前
谷歌Chrome浏览器即将对HTTP网站设卡:突出展示“始终使用安全连接”功能
前端·网络·chrome·http·搜索引擎·seo·数字营销
韶关亿宏科技-光纤通信小易9 小时前
光模块-数字时代的算力传输纽带
大数据·网络
AC赳赳老秦9 小时前
Unity游戏开发实战指南:核心逻辑与场景构建详解
开发语言·spring boot·爬虫·搜索引擎·全文检索·lucene·deepseek