当前位置: 首页 > news >正文

Elasticsearch高级搜索技术-结构化数据搜索

目录

结构化数据的存储

示例映射

使用range查询

查询示例

运算符

更多示例

日期查询

示例


    结构化数据搜索是Elasticsearch另一个强大的功能,允许用户对具有明确类型的数据(如数字、日期和布尔值)进行精确的过滤和查询。这种类型的搜索通常涉及使用比较运算符来匹配特定条件。                

结构化数据的存储

当将结构化数据存储到Elasticsearch时,你需要定义一个映射(mapping),这个映射描述了每个字段的数据类型。例如,在电子商务网站的商品索引中,price字段可以被定义为floatinteger类型,这取决于价格是否包含小数点。

示例映射
PUT /products
{"mappings": {"properties": {"name": { "type": "text" },"description": { "type": "text" },"price": { "type": "float" },"available": { "type": "boolean" },"created_at": { "type": "date" }}}
}

使用range查询

range查询允许你根据数值范围来过滤文档。你可以指定一个或多个边界,并且可以设置这些边界的开闭性(即是否包括边界值)。这对于筛选出符合特定条件的记录非常有用,比如价格低于某个阈值的所有商品。

查询示例

假设我们想要找到所有价格低于100元的商品:

GET /products/_search
{"query": {"range": {"price": {"lt": 100  // 小于100}}}
}

在这个例子中:

  • lt (less than) 指定了价格必须小于100。
  • 如果你想包括等于的情况,可以使用lte (less than or equal to)。

运算符

除了ltlte之外,还有其他几个常用的运算符:

  • gt (greater than): 大于
  • gte (greater than or equal to): 大于或等于
  • from 和 to: 可以用来指定一个范围,其中from代表下限,to代表上限
更多示例

查找价格在50至200之间的商品:

GET /products/_search
{"query": {"range": {"price": {"gte": 50,  // 大于或等于50"lte": 200   // 小于或等于200}}}
}

日期查询

对于日期字段,range查询同样适用。你可以用日期字符串或者时间戳来进行比较。

示例

查找在过去一个月内创建的所有商品:

GET /products/_search
{"query": {"range": {"created_at": {"gte": "now-1M/M",  // 大于或等于上个月初"lt": "now/M"       // 小于本月月初}}}
}

这里的now-1M/M表示从当前时间减去一个月,并且取该月的第一天;now/M则表示当前月份的第一天。

 

http://www.lryc.cn/news/459907.html

相关文章:

  • ffmpeg面向对象——类所属的方法探索
  • TensorRT-LLM七日谈 Day3
  • 如何使用Pandas库处理大型数据集?
  • XHR 创建对象
  • # 在执行 rpm 卸载软件使用 nodeps 参数时,报错 error: package nodeps is not installed 分析
  • C++的类和动态内存分配(深拷贝与浅拷贝)并实现自己的string类
  • 通过观测云 DataKit Extension 接入 AWS Lambda 最佳实践
  • MySQL-三范式 视图
  • 多线程(三):线程等待获取线程引用线程休眠线程状态
  • Hi3244 应用指导
  • 【LeetCode热题100】哈希
  • Java的四种循环语句
  • Qt杂记目录
  • 项目开发--基于docker实现模型容器化服务
  • C语言 | Leetcode C语言题解之第477题汉明距离总和
  • Bug剖析
  • HI3516DV500 相机部分架构初探
  • 训练yolo系列出现问题mAP, R, P等为零
  • 数字媒体技术基础:色度子采样(4:4:4、4:2:2 、4:2:0)
  • tkinter库的应用小示例:文本编辑器
  • 信息抽取数据集处理——RAMS
  • SpringBoot+XXL-JOB:高效定时任务管理
  • openpyxl -- 简介
  • 滚雪球学MySQL[8.3讲]:数据库中的JSON与全文检索详解:从数据存储到全文索引的高效使用
  • position定位静态定位/绝对定位/相对定位
  • 2024年09月CCF-GESP编程能力等级认证C++编程三级真题解析
  • Web自动化Demo-PHP+Selenium
  • Python速成笔记——知识(GUI自动化处理屏幕和按键输出)
  • 计算机是如何输入存储输出汉字、图片、音频、视频的
  • springboot系列--web相关知识探索五