ElasticSearch:数据的魔法世界

在这里插入图片描述

欢迎来到ElasticSearch的奇妙之旅!在这个充满魔法的搜索引擎世界中,数据不再是沉闷的数字和字母,而是变得充满活力和灵动。无论你是刚刚踏入数据探索的小白,还是已经对搜索引擎有所了解的行者,本篇博客都将为你揭示ElasticSearch的神奇之处。

ElasticSearch简介:探秘搜索引擎的奇妙

ElasticSearch,这个名字听起来像是来自魔法世界的秘密组织,但实际上,它是一款强大的开源搜索引擎。ElasticSearch基于Lucene构建而成,不仅仅是搜索引擎,还是实时的分布式文档存储,具备全文搜索和分析能力。

魔法1:索引与文档的魔法花园

在ElasticSearch的王国里,数据被组织成索引和文档的结构。索引类似于传统数据库中的表,而文档则是我们实际存储的数据单元。让我们一起来创造一些魔法吧!

首先,让我们创造一个名为products的索引:

PUT /products
{"mappings": {"properties": {"name": { "type": "text" },"price": { "type": "float" },"category": { "type": "keyword" }}}
}

这段魔法咒语创建了一个名为products的索引,并定义了文档中的字段类型。接下来,让我们添加一些商品的魔法文档:

POST /products/_doc/1
{"name": "Magic Wand","price": 19.99,"category": "Enchantment"
}POST /products/_doc/2
{"name": "Invisibility Cloak","price": 99.99,"category": "Apparel"
}POST /products/_doc/3
{"name": "Potion of Wisdom","price": 49.99,"category": "Consumables"
}

通过这些魔法文档,我们在products索引中创造了一些商品的奇妙信息。

魔法2:搜索与查询的奇迹

ElasticSearch最强大的能力之一就是其搜索和查询的魔法。让我们通过一些简单的咒语感受一下:

全文搜索咒语:

如果我们想要找到所有包含关键词"cloak"的商品:

GET /products/_search
{"query": {"match": {"name": "cloak"}}
}

这个咒语将返回所有商品中名称包含"cloak"的文档。

精确匹配咒语:

如果我们想要查找属于"Apparel"类别的商品:

GET /products/_search
{"query": {"term": {"category.keyword": "Apparel"}}
}

这个咒语将返回所有类别为"Apparel"的商品文档。

范围查询咒语:

如果我们想要查找价格在50到100之间的商品:

GET /products/_search
{"query": {"range": {"price": {"gte": 50,"lte": 100}}}
}

这个咒语将返回价格在50到100之间的所有商品文档。

魔法3:聚合与分析的仪式

ElasticSearch不仅仅能找到数据,还能进行聚合和分析的魔法仪式。通过聚合,我们能够获得关于数据的统计信息,进行数据挖掘和分析。

聚合统计仪式:

假设我们想要统计每个类别的商品数量:

GET /products/_search
{"aggs": {"categories": {"terms": {"field": "category.keyword"}}}
}

这个仪式将返回每个类别的商品数量统计。

范围聚合仪式:

如果我们想要统计商品价格的分布情况:

GET /products/_search
{"aggs": {"price_ranges": {"range": {"field": "price","ranges": [{ "to": 50 },{ "from": 50, "to": 100 },{ "from": 100 }]}}}
}

这个仪式将返回商品价格在不同范围内的数量统计。

ElasticSearch与应用程序的交响乐

在实际应用中,我们往往需要将ElasticSearch与我们的应用程序交织在一起,共同奏响数据的交响乐。在Java应用中,我们可以使用Spring Data Elasticsearch来实现这样的集成。

首先,添加相关的依赖到你的项目中:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

然后,配置ElasticSearch连接信息:

spring:data:elasticsearch:cluster-name: your-cluster-namecluster-nodes: your-cluster-nodes

接下来,创建一个实体类,用于映射ElasticSearch中的文档:

@Document(indexName = "products")
public class Product {@Idprivate String id;private String name;private float price;private String category;// 省略getter和setter=
}

通过@Document注解,我们指定了文档所属的索引名称。@Id注解用于标识文档的唯一标识。

最后,创建一个Repository接口,用于执行查询操作:

public interface ProductRepository extends ElasticsearchRepository<Product, String> {List<Product> findByCategory(String category);
}

通过继承ElasticsearchRepository接口,我们能够轻松地执行各种查询操作,而不需要编写具体的实现代码。

小结:数据的奇妙之旅

通过这篇博客,我们只是轻轻触摸了ElasticSearch的表面,探索了其强大的搜索、查询、聚合和分析能力。ElasticSearch不仅是一款搜索引擎,更是一项让数据变得有趣而强大的技术。希望在这段奇妙的旅程中,你能够对ElasticSearch有了初步的了解,并愿意深入挖掘其更多的神奇之处。在数据的魔法世界里,让我们共同奏响交响乐,感受搜索引擎的魅力。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

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

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

相关文章

unity内存优化之AB包篇(微信小游戏)

1.搭建资源服务器使用(HFS软件(https://www.pianshen.com/article/54621708008/)) using System.Collections; using System.Collections.Generic; using UnityEngine;using System;public class Singleton<T> where T : class, new() {private static readonly Lazy<…

【集成开发环境】-VS Code:C/C++ 环境配置

简介 VS Code&#xff0c;全称Visual Studio Code&#xff0c;是一款由微软开发的跨平台源代码编辑器。它支持Windows、Linux和macOS等操作系统&#xff0c;并且具有轻量级、高效、可扩展等特点&#xff0c;深受广大开发者的喜爱。 VS Code拥有丰富的功能特性&#xff0c;包括…

c语言(字符串函数和内存函数的模拟实现)

1、模拟strlen&#xff08;临时变量法&#xff09; #include <stdio.h> #include <assert.h> int my_strlen(const char* str); int main() {char str[] "abcdefh";int ret my_strlen(str);printf("%d", ret);return 0; } int my_strlen( c…

代码随想录算法训练营第四十七天|198.打家劫舍, 213.打家劫舍II , 337.打家劫舍III

198.打家劫舍 https://leetcode.com/problems/house-robber/description/ 思路&#xff1a; 经典的动态规划问题&#xff0c;首先确定dp 数组记录的是打劫到第i家时的收获&#xff0c; dp[0] 0&#xff0c; dp[1] values[0]. 然后到第i 家有两个选择&#xff0c; 一个是打劫…

koa2+vue3通过exceljs实现数据导出excel文档

服务端安装exceljs依赖 npm i exceljs服务端实现代码 实现导出excel文件工具方法 const ExcelJS require(exceljs); /*** description: 导出excel文件* param {*} fileHeader 导出的表头* param {*} data 导出的数据* param {*} ctx 上下文对象* return {*}*/ async funct…

计算机三级网络技术综合题第三题、第四题详细解析

第三大题 DHCP报文分析&#xff08;10分&#xff09; 一、DHCP工作流程&#xff08;一般情况下&#xff09; 报文摘要 对应上面报文1—4 报文1、3DHCP&#xff1a;Request&#xff1b; 报文2、4DHCP&#xff1a;Reply。 例题&#xff08;第三套&#xff09;&#xff1a;在一…

Flutter 当涉及Listview的复杂滑动布局良好布局方式

目录 引 代码以及概叙 详细解释 SingleChildScrollView shrinkWrap 属性 NeverScrollableScrollPhysics 引 当我们构建界面&#xff0c;很多时候都会需要显示一个能滑动的流布局&#xff0c;同时这个布局还要有些其他的界面元素&#xff0c;同时在flutter中&#xff0c;滑…

大型项目中的敏捷开发实践:原则、方法与工具的应用经验分享

引言 在软件开发领域&#xff0c;大型项目往往伴随着高风险和复杂性&#xff0c;传统的瀑布模型往往难以应对快速变化的需求和不确定的环境。而敏捷开发方法以其灵活、快速响应变化的特点&#xff0c;逐渐成为大型项目管理的有力武器。本文旨在分享我在大型项目中应用敏捷开发…

程序员入行忠告!

点击下方“JavaEdge”&#xff0c;选择“设为星标” 第一时间关注技术干货&#xff01; 关注我&#xff0c;紧跟本系列专栏文章&#xff0c;咱们下篇再续&#xff01; 作者简介&#xff1a;魔都技术专家兼架构&#xff0c;多家大厂后端一线研发经验&#xff0c;各大技术社区头部…

十大经典排序之归并排序

文章目录 概要整体架构流程代码实现小结 概要 归并排序&#xff08;Merge sort&#xff09;是建立在归并操作上的一种有效的排序算法。该算法是采用分治法&#xff08;Divide and Conquer&#xff09;的一个非常典型的应用。 作为一种典型的分而治之思想的算法应用&#xff0…

十五、自回归(AutoRegressive)和自编码(AutoEncoding)语言模型

参考自回归语言模型&#xff08;AR&#xff09;和自编码语言模型&#xff08;AE&#xff09; 1 自回归语言模型&#xff08; AR&#xff09; 自回归语言模型&#xff08;AR&#xff09;就是根据上文内容&#xff08;或下文内容&#xff09;预测下一个&#xff08;或前一个&…

安装OpenEBS,镜像总是报错ImagePullBackOff或者ErrImagePull的解决方法

按照 KubeSphere 官方文档安装 OpenEBS&#xff0c;镜像总是报错ImagePullBackOff或者ErrImagePull的解决方法 helm 有很多更换 源 的文章&#xff0c;有一些是写更换阿里云的源&#xff0c;但是阿里云的源根本没更新OpenEBS的镜像。 在网上找到1个可用的源&#xff1a; 可用的…

VSCODE的常用插件

1、中文设置 &#xff08;1&#xff09;搜索 chinese Chinese (Simplified) Language Pack for Visual Studio Code C/C Extension Pack &#xff08;2&#xff09;配置 通过使用“Configure Display Language”命令显式设置 VS Code 显示语言&#xff0c;可以替代默认 UI…

计算最长的字符串长度

本题要求实现一个函数&#xff0c;用于计算有n个元素的指针数组s中最长的字符串的长度。 函数接口定义&#xff1a; int max_len( char *s[], int n ); 其中n个字符串存储在s[]中&#xff0c;函数max_len应返回其中最长字符串的长度。 裁判测试程序样例&#xff1a; #inclu…

Django性能优化

1.服务器CPU太高的优化 1>在Django项目中使用line_profiler进行性能剖析&#xff0c;您需要遵循以下步骤来设置并使用它&#xff1a; 注&#xff1a;此种方式似乎中间件无法启动&#xff01;&#xff01;&#xff01; 要使用Django与line_profiler进行特定视图的性能测试…

探讨TCP的可靠性以及三次握手的奥秘

&#x1f31f; 欢迎来到 我的博客&#xff01; &#x1f308; &#x1f4a1; 探索未知, 分享知识 !&#x1f4ab; 本文目录 1. TCP的可靠性机制1.2可靠性的基础上,尽可能得提高效率 2. TCP三次握手过程3. 为何不是四次握手&#xff1f; 在互联网的复杂世界中&#xff0c;TCP&am…

基于springboot的高校教师教研信息填报系统

文章目录 项目介绍主要功能截图&#xff1a;部分代码展示设计总结项目获取方式 &#x1f345; 作者主页&#xff1a;超级无敌暴龙战士塔塔开 &#x1f345; 简介&#xff1a;Java领域优质创作者&#x1f3c6;、 简历模板、学习资料、面试题库【关注我&#xff0c;都给你】 &…

SpringBoot3整合Redis基础操作

SpringBoot3整合Redis&基础应用 配套视频&#xff1a;SpringBoot3整合Redis&基础操作视频 1. 概述 SpringBoot是一种用于构建Java应用程序的开发框架&#xff0c;Redis是一个高性能的键值存储数据库&#xff0c;常用于缓存、会话管理、消息队列等应用场景&#xff0…

亚马逊云科技Glue

Glue 最重要的部分&#xff0c; ETL&#xff1a;用于从 A 点&#xff08;我们的源数据&#xff09;提取、转换和加载数据到 B 点&#xff08;目标文件或数据存储库&#xff09;。 AWS Glue 会为您执行大量此类工作。 转换通常是更繁重的工作&#xff0c;需要从各种来源进行组合…

【嵌入式DIY实例】-自动割草机器

自动割草机器 文章目录 自动割草机器1、割草机器介绍2、硬件准备3、功能设计4、硬件接线5、代码实现本文将介绍如何使用 Arduino 构建一个简易自动割草机机器人或割草机机器人。该机器人可以自动剪掉花园里多余的草。如果花园里有障碍物,它会自动改变方向。帮助以减少人力。 警…