Elasticsearch 中,term 查询和 match 查询的区别

文章目录

  • 前言
    • [Elasticsearch 中,term 查询和 match 查询的区别](#Elasticsearch 中,term 查询和 match 查询的区别)
      • [1. Term 查询](#1. Term 查询)
      • [2. Match 查询](#2. Match 查询)
      • [3. 总结](#3. 总结)

前言

如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。

而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


Elasticsearch 中,term 查询和 match 查询的区别

1. Term 查询

  • 精确匹配:term 查询用于精确匹配字段的内容,不进行分词。它适用于关键词或精确值的匹配,比如数值、日期、布尔值或者不需要分词的字符串(如ID、邮政编码)。
  • 不分词:如果查询的字段是文本类型,term 查询不会对查询字符串进行分词,而是直接匹配整个词。例如,查询"user":"John Doe"时,它只会匹配整个字段为"John Doe"的文档,而不会匹配包含"John"或"Doe"的文档。
bash 复制代码
GET /blog_new/_search
{
  "query": {
    "term": {
      "title.keyword": "jstat命令查看jvm的GC信息1"
    }
  },
  "size": 1000 
}

2. Match 查询

  • 全文检索:match 查询用于全文检索,它会对查询的文本进行分词,然后搜索这些分词的匹配。适用于自然语言文本的搜索。
  • 分词匹配:对于文本类型的字段,match 查询会将输入的字符串分成多个词条,然后搜索与这些词条匹配的文档。例如,查询"user":"John Doe"时,它会将字符串分词为"John"和"Doe",然后搜索包含这两个词的文档。
bash 复制代码
GET /blog_new/_search
{
  "query": {
    "match": {
      "title": "jstat命令查看jvm的GC信息1"
    }
  },
  "size": 1000 
}

3. 总结

如果需要精确匹配某个值,应该使用term查询。

如果需要进行全文搜索或模糊匹配,应该使用match查询。

相关推荐
隔着天花板看星星5 分钟前
Kafka-Consumer理论知识
大数据·分布式·中间件·kafka
holywangle7 分钟前
解决Flink读取kafka主题数据无报错无数据打印的重大发现(问题已解决)
大数据·flink·kafka
隔着天花板看星星8 分钟前
Kafka-副本分配策略
大数据·分布式·中间件·kafka
Lorin 洛林27 分钟前
Hadoop 系列 MapReduce:Map、Shuffle、Reduce
大数据·hadoop·mapreduce
DolphinScheduler社区43 分钟前
大数据调度组件之Apache DolphinScheduler
大数据
SelectDB技术团队43 分钟前
兼顾高性能与低成本,浅析 Apache Doris 异步物化视图原理及典型场景
大数据·数据库·数据仓库·数据分析·doris
panpantt3212 小时前
【参会邀请】第二届大数据与数据挖掘国际会议(BDDM 2024)邀您相聚江城!
大数据·人工智能·数据挖掘
青云交2 小时前
大数据新视界 -- 大数据大厂之 Impala 性能优化:跨数据中心环境下的挑战与对策(上)(27 / 30)
大数据·性能优化·impala·案例分析·代码示例·跨数据中心·挑战对策
soso19682 小时前
DataWorks快速入门
大数据·数据仓库·信息可视化
The_Ticker2 小时前
CFD平台如何接入实时行情源
java·大数据·数据库·人工智能·算法·区块链·软件工程