Elasticsearch(es)中must以及term的基本使用

文章目录

    • should 和 must
    • term 和 range
    • 常见的查询方式

should 和 must

在 Elasticsearch(ES)中,should 和 must 是布尔查询(Boolean Query)中常用的两个子句。

  1. should 子句:should 表示一个或多个条件之一满足即可匹配文档。它类似于逻辑上的 OR 操作,用于构建可选项或者提升匹配文档的相关性评分。当至少一个 should 子句匹配时,文档将被认为是匹配的。
  2. must 子句:must 表示所有条件都必须满足才能匹配文档。它类似于逻辑上的 AND 操作,用于构建必须满足的查询限制。只有当所有的 must 子句都匹配时,文档才会被认为是匹配的。

需要注意的是,should 和 must 子句可以同时在一个布尔查询中使用,以构建更复杂的查询逻辑。

以下是一个示例,演示了如何在布尔查询中使用 should 和 must 子句:

{"query": {"bool": {"must": [{ "term": { "field1": "value1" } },{ "term": { "field2": "value2" } }],"should": [{ "term": { "field3": "value3" } },{ "term": { "field4": "value4" } }]}}
}

在上述示例中,must 子句包含了两个条件,即 field1 的值必须为 “value1”,并且 field2 的值必须为 “value2”。这两个条件都必须满足才能匹配文档。

而 should 子句包含了两个条件,即 field3 的值可以为 “value3” 或者 field4 的值可以为 “value4”。只要满足其中一个条件,文档就会被认为是匹配的。

term 和 range

在 Elasticsearch(ES)中,term 和 range 是查询语句中常用的两种查询类型。

  1. term 查询:term 查询用于精确匹配某个字段的值。它会搜索指定字段中与给定项完全匹配的文档。term 查询是基于倒排索引的精确匹配查询,适用于关键字、枚举值等不需要分词的字段。
    以下是一个示例,演示如何使用 term 查询:
{"query": {"term": {"field": "value"}}
}

在上述示例中,term 查询用于匹配 field 字段的值为 “value” 的文档。

  1. range 查询:range 查询用于匹配指定字段中的范围值。它可以匹配数值、日期等类型的字段,并允许指定包含、不包含等关系运算符。
    以下是一个示例,演示如何使用 range 查询:
{"query": {"range": {"field": {"gte": 10,"lte": 20}}}
}

在上述示例中,range 查询用于匹配 field 字段的值在 10 到 20 之间(包含边界值)的文档。

range 查询支持以下关系运算符:

  • gt:大于
  • gte:大于等于
  • lt:小于
  • lte:小于等于
    通过组合这些运算符,可以构建各种范围查询条件。

需要注意的是,在使用 range 查询时,字段的类型必须是可排序的,例如数值或日期类型。

常见的查询方式

Elasticsearch(ES)提供了多种查询方式,用于根据不同的需求进行数据检索和分析。以下是一些常用的 ES 查询方式:

  1. Match 查询:用于执行全文本搜索,匹配特定字段中包含给定词条的文档。它会对搜索词进行分词,然后在索引中查找匹配的文档。

  2. Term 查询:用于精确匹配某个字段的值。它会搜索指定字段中与给定项完全匹配的文档。Term 查询适用于关键字、枚举值等不需要分词的字段。

  3. Range 查询:用于匹配指定字段中的范围值。它可以匹配数值、日期等类型的字段,并允许指定包含、不包含等关系运算符。

  4. Bool 查询:用于执行布尔逻辑组合的查询。可以使用 must、should 和 must_not 子句来构建复合查询,实现与、或、非等逻辑运算。

  5. Match Phrase 查询:类似于 Match 查询,但要求匹配的词条必须按顺序连续出现在文档中。

  6. Wildcard 查询:用于执行通配符搜索,匹配指定字段中符合通配符模式的文档。

  7. Fuzzy 查询:用于执行模糊搜索,匹配与指定词条相似的文档。它可以处理拼写错误、近似词等情况。

  8. Aggregations(聚合查询):用于执行数据分析和聚合操作,例如计算平均值、求和、分组等。

  9. Nested 查询:用于查询嵌套对象的属性。它可以在嵌套的对象或数组字段中执行查询。

  10. Geo 查询:用于执行地理位置相关的查询,例如搜索附近的地点、根据地理坐标过滤等。

这只是一部分常用的 ES 查询方式,ES 还提供了更多功能强大的查询类型和查询参数,用于满足各种数据检索和分析的需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/633550.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

10个常考的前端手写题,你全都会吗?

前言 📫 大家好,我是南木元元,热爱技术和分享,欢迎大家交流,一起学习进步! 🍅 个人主页:南木元元 今天来分享一下10个常见的JavaScript手写功能。 目录 1.实现new 2.call、apply、…

AliyunECS服务器在安装docker服务时一直出现:错误:为仓库 ‘root_n‘ 下载元数据失败

AliyunECS服务器在安装docker服务时一直出现:错误:为仓库 root_n 下载元数据失败 一、AliyunECS服务器在安装docker服务时一直出现:错误:为仓库 root_n 下载元数据失败endl 一、AliyunECS服务器在安装docker服务时一直出现:错误:为仓库 ‘roo…

Python爬虫---scrapy框架---当当网管道封装

项目结构: dang.py文件:自己创建,实现爬虫核心功能的文件 import scrapy from scrapy_dangdang_20240113.items import ScrapyDangdang20240113Itemclass DangSpider(scrapy.Spider):name "dang" # 名字# 如果是多页下载的话, …

transbigdata笔记:轨迹切片

1 方法介绍 在transbigdata笔记:轨迹停止点和行程提取-CSDN博客中,已经可以把轨迹点拆分成停止点和行程点,但是行程点只有起止位置,不包含行程轨迹信息为了进一步分析车辆的行驶轨迹,需要从每次行程的时间段中提取轨迹…

matlab Robotics Toolbox

工具箱下载地址:ROBOTICS TOOLBOX 安装教程 笛卡尔运动规划 在MATLAB中,ctraj和jtraj是两个不同的函数,主要用于控制系统和机器人学中的轨迹规划。它们之间的主要区别在于它们处理的问题类型和使用方式。 ctraj(连续时间轨迹规划…

一文解读ISO26262安全标准:术语

一文解读ISO26262安全标准:术语 做汽车行业的人,都知道安全标准ISO26262,但是仔细说说它到底讲的是什么?好像又说不出来,这是个玄之又玄的话题,笔者试图将这份标准以简明扼要、并且容易理解的形式梳理出来&…

Milvus 上新:支持上万个 Collection、新增 Accesslog 功能……

2024 年开年,Milvus 好消息不断。除了收获 Github 25,000 颗星的成就,Milvus 也发布了新年的第一个版本—— 2.3.4。 此次发版的主要目的是为用户提供一个高扩展性且更易用的 Milvus 版本。为此,Milvus 新增了许多易用性功能,比如…

CTF CRYPTO 密码学-2

题目名称:crypto1 题目描述: 字符 ZZZZ X XXZ ZZ ZXZ Z ZXZ ZX ZZX XXX XZXX XXZ ZX ZXZZ ZZXZ XX ZX ZZ 分析 此字段是由Z和X组成的字符,联想到莫斯密码是由.和-组成的所以接下来可以尝试莫斯密码解题 解题过程: Step1&#xf…

c++ 指针的初始化

为指针正确赋值可以避免未定义行为(如野指针)。指针可以指向变量、数组、另一个指针(多级指针)、函数等。 指针的初始化可以在声明时进行,也可以在声明之后进行。 初始化为 nullptr 从 C11 开始,建议初始…

财务涉及到的金额之间的关系

财务涉及到的金额之间的关系 无税金额 含税金额 / (1 税率)含税金额 无税金额 * (1 税率)税额 无税金额 * 税率 含税金额 / (1 税率) 税率税率{0.03、0.13…}

2019年认证杯SPSSPRO杯数学建模C题(第二阶段)保险业的数字化变革全过程文档及程序

2019年认证杯SPSSPRO杯数学建模 基于统计建模的车险业数字变革研究 C题 保险业的数字化变革 原题再现: 车险,即机动车辆保险。保险自身是一种分散风险、消化损失的经济补偿制度,车险即为分散机动车辆在行驶过程中可能发作的未知风险和损失…

【Vue】Vue 路由的配置及使用

目录捏 前言一、路由是什么?1.前端路由2.后端路由 二、路由配置1.安装路由2.配置路由 三、路由使用1.route 与 router2. 声明式导航3. 指定组件的呈现位置 四、嵌套路由(多级路由)五、路由重定向1.什么是路由重定向?2.设置 redire…

奇安信天擎 rptsvr 任意文件上传漏洞复现

0x01 产品简介 奇安信天擎是奇安信集团旗下一款致力于一体化终端安全解决方案的终端安全管理系统(简称“天擎”)产品。通过“体系化防御、数字化运营”方法,帮助政企客户准确识别、保护和监管终端,并确保这些终端在任何时候都能可信、安全、合规地访问数据和业务。天擎基于…

C++类与对象【友元】

🌈个人主页:godspeed_lucip 🔥 系列专栏:C从基础到进阶 🎄1 友元🥑1.1 全局函数做友元🥑1.2 类做友元🥑1.3 成员函数做友元 🕮2 总结 🎄1 友元 生活中你的家…

ContentNegotiationManagerFactoryBean 内容协商

一.什么是内容协商 简单点说,就是同一资源,可以有多种表现形式,比如xml、json等,具体使用哪种表现形式,是可以协商的。 这是RESTfull的一个重要特性,Spring Web MVC也支持这个功能。 1.Spring MVC REST是如何决定采用…

深入了解性能优化(web应用)

影响一个系统性能的方方面面 一个 web应用不是一个孤立的个体,它是一个系统的部分,系统中的每一部分都会影响整个系统的性能 一.常用的性能评价/测试指标 1.响应时间 提交请求和返回该请求的响应之间使用的时间,一般比较关注平均响应时间。 常用操作的响应时间列表: 操作 响应…

深入理解Scrapy中XPath的`following-sibling`选择器

什么是XPath? 在深入following-sibling选择器之前,先简单了解一下XPath。XPath是一种在XML文档中查找信息的语言。它同样适用于HTML文档,因为HTML是XML的一种形式。XPath使用路径表达式在XML文档中进行导航。在网络爬虫框架Scrapy中&#xf…

探索 2024 年新副业:无人饮品机的新风向

随着科技的迅猛发展,无人饮品机作为一种全新的商业模式,正逐渐成为 2024 年副业的新风向。如果你还没有了解过这种全新的副业,那么现在是时候深入了解一下了。 D咖无人饮品机的优势在于其 24 小时不间断的营业模式,它可以在你睡觉…

Educational Codeforces Round 161 (Rated for Div. 2)补题

Tricky Template(Problem - A - Codeforces) 题目大意:现有三个模板字串a,b,c,都由小写字母组成,问能否找到一个字串s,使s与a,b匹配,与c不匹配,匹配的条件如下: 如果s的某位为小写…

边缘计算和联邦学习的联系

1. 什么是边缘计算? 边缘计算(Edge Computing)是一种计算模型,其主要思想是将计算、存储和数据处理能力推送到离数据源近的边缘设备,而不是依赖于远程的云服务器。这样做的目的是减少数据传输延迟、提高响应速度&…