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

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-name
      cluster-nodes: your-cluster-nodes

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

@Document(indexName = "products")
public class Product {
    @Id
    private 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.kler.cn/a/272173.html

相关文章:

  • (undone) 并行计算学习 (Day2: 什么是 “伪共享” ?)
  • 一文了解如何在Qt中间集成Halcon窗口并在子线程显示(附工程源码下载链接)
  • 工业制造离不开的BOM
  • PyTorch使用教程(10)-torchinfo.summary网络结构可视化详细说明
  • vulnhub靶场【IA系列】之Tornado
  • 3 前端(中):JavaScript
  • 使用 300 元的显卡推理 Qwen1.5-14B
  • Qt的XML文件读取测试01
  • SQLiteC/C++接口详细介绍之sqlite3类(六)
  • 【开源鸿蒙】编译OpenHarmony轻量系统QEMU RISC-V版
  • OpenAI引领下一代AI技术,推出GPT-4 Turbo
  • rust - 一个日志缓存记录的通用实现
  • Transformer的前世今生 day02(神经网络语言模型
  • 【开源鸿蒙】模拟运行OpenHarmony轻量系统QEMU RISC-V版
  • uwsgi+nginx+django 部署学习
  • cache的58问,您能回答上几个
  • 课时67:流程控制_for循环_for基础
  • 万界星空科技商业开源MES,技术支持+项目合作
  • vulhub中GitLab 任意文件读取漏洞复现(CVE-2016-9086)
  • MATLAB中的cell数组和结构体。
  • 安全地使用v-html
  • 深度学习pytorch——基本运算(持续更新)
  • 微信小程序之tabBar
  • LinkedList源码解析和设计思路
  • 强大的开源网络爬虫框架Scrapy的基本介绍(入门级)
  • 在类Unix平台实现TCP客户端