Elasticsearch模糊查询之Wildcard

{"wildcard" : { "LPR.keyword" : { "wildcard" : "${Keyword}"} }},你的示例中使用了 wildcard 查询,它适用于模糊搜索,允许使用通配符(* 和 ?)来匹配字段值。你使用了 keyword 子字段来确保精确匹配,这是一个常见的做法,因为 keyword 字段不会进行分词,可以直接用于通配符查询。

示例解释

假设你的索引中有一个字段 LPR,它被定义为一个 text 字段,同时有一个 keyword 子字段用于精确匹配和通配符查询:

映射定义示例

复制代码
PUT /my_index
{
  "mappings": {
    "properties": {
      "LPR": {
        "type": "text",
        "fields": {
          "keyword": {
            "type": "keyword"
          }
        }
      }
    }
  }
}

wildcard 查询示例

你想要在 LPR.keyword 字段中进行通配符查询,以下是查询的 JSON 格式:

复制代码
GET /my_index/_search
{
  "query": {
    "wildcard": {
      "LPR.keyword": {
        "wildcard": "${Keyword}"
      }
    }
  }
}

wildcard 查询用于匹配符合通配符模式的文档。

LPR.keyword 指定要在 LPR 字段的 keyword 子字段上进行查询。

${Keyword} 是一个变量,代表你要搜索的通配符模式(例如,abc ,abc*,a*c,等)。

示例查询

假设你想要查找所有在 LPR 字段中包含 "abc" 的文档,你可以将 ${Keyword} 替换为实际的通配符模式:

复制代码
GET /my_index/_search
{
  "query": {
    "wildcard": {
      "LPR.keyword": {
        "wildcard": "*abc*"
      }
    }
  }
}

详细解释

"abc ":这个通配符模式表示匹配所有包含 "abc" 的文档,无论 "abc" 前后有多少字符。

使用注意事项

性能:通配符查询,特别是以 * 开头的查询(例如 "abc "),可能会很慢,因为它们需要扫描大量文档。对于大数据集,最好避免这种查询,或者使用其他索引优化策略。

大小写敏感:keyword 字段是大小写敏感的。如果需要大小写不敏感的匹配,可以考虑在索引时标准化数据(例如,转换为小写)。

Wildcard(通配符)中的*和?区别

Wildcard(通配符)中的*和?在功能和使用上存在明显的区别,主要体现在它们所能匹配的字符数量和范围上。

  1. *(星号)
    功能:在通配符中代表零个、一个或多个字符。这意味着它可以匹配任意长度的字符串,包括空字符串。
    使用场景:常用于模糊搜索,特别是在需要匹配多个字符或者不确定具体字符数量的情况下。例如,在文件名匹配中,.txt可以匹配所有以.txt结尾的文件,无论其前缀是什么。
    注意事项:由于可以匹配任意长度的字符串,包括零个字符,因此在某些情况下可能会导致意外的匹配结果。因此,在使用时需要特别注意匹配模式的精确性。
  2. ?(问号)
    功能:?在通配符中代表任意一个字符。这意味着它只能匹配一个字符,无论这个字符是什么。
    使用场景:?通常用于需要精确匹配一个字符但不确定这个字符具体是什么的情况。例如,在文件名匹配中,report?.txt可以匹配report1.txt、reportA.txt等,但不会匹配report.txt或reporttwo.txt。
    注意事项:由于?只能匹配一个字符,因此在使用时需要确保匹配模式中的?数量与要匹配的字符数量一致。
相关推荐
Dxy12393102163 小时前
Elasticsearch 8.13.4 深度进阶指南:从底层架构到高阶实战的全维突围
大数据·elasticsearch·架构
a努力。3 小时前
中国电网Java面试被问:RPC序列化的协议升级和向后兼容
java·开发语言·elasticsearch·面试·职场和发展·rpc·jenkins
Hello.Reader4 小时前
Flink Elasticsearch Connector 从 0 到 1 搭一个高吞吐、可容错的 ES Sink
大数据·elasticsearch·flink
小雪_Snow5 小时前
Elasticsearch 安装教程【Windows,9.2.0 版本】
elasticsearch
Elastic 中国社区官方博客1 天前
使用 Elasticsearch 管理 agentic 记忆
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
七夜zippoe1 天前
Elasticsearch核心概念与Java客户端实战 构建高性能搜索服务
java·大数据·elasticsearch·集群·索引·分片
忍冬行者2 天前
Elasticsearch 超大日志流量集群搭建(网关 + 独立 Master + 独立 Data 纯生产架构,角色完全分离,百万级日志吞吐)
大数据·elasticsearch·云原生·架构·云计算
·云扬·2 天前
使用Prometheus+Grafana实现Elasticsearch监控的完整实践
elasticsearch·grafana·prometheus
阿杰 AJie2 天前
Git 分支与多人开发使用指南(Gitee + 本地 Git)
git·elasticsearch·gitee
海鸥812 天前
ArgoCD App of Apps 模式详解
java·elasticsearch·argocd