在Elasticsearch中-SpaceJam一个全文搜索的实例

news/2024/10/19 0:22:02/

在Elasticsearch中进行全文搜索通常涉及几个步骤:创建索引、定义映射、索引文档、执行搜索查询。下面我将通过一个名为"SpaceJam"的虚构实例来演示如何进行全文搜索。

### 步骤 1: 创建索引

首先,我们需要创建一个索引。在这个例子中,我们假设我们正在索引关于电影的信息。

```json
PUT /space_jam
{
  "settings": {
    "number_of_shards": 1,
    "number_of_replicas": 1
  }
}
```

### 步骤 2: 定义映射

接下来,我们为索引定义映射。映射将指定每个字段的数据类型和分析器。

```json
PUT /space_jam/_mapping
{
  "properties": {
    "title": {
      "type": "text",
      "analyzer": "english"
    },
    "description": {
      "type": "text",
      "analyzer": "english"
    },
    "release_date": {
      "type": "date",
      "format": "yyyy-MM-dd"
    },
    "director": {
      "type": "text",
      "analyzer": "standard"
    }
  }
}
```

在这个映射中,我们使用了`english`分析器来处理`title`和`description`字段,使用`standard`分析器来处理`director`字段。

### 步骤 3: 索引文档

现在我们可以向索引中添加文档。例如,我们可以添加关于电影《Space Jam》的文档。

```json
POST /space_jam/_doc
{
  "title": "Space Jam",
  "description": "Michael Jordan teams up with the Looney Tunes to defeat a group of aliens.",
  "release_date": "1996-11-15",
  "director": "Joe Pytka"
}
```

### 步骤 4: 执行搜索查询

最后,我们可以执行全文搜索查询。例如,如果我们想要找到包含"Michael Jordan"的所有文档,我们可以执行以下查询:

```json
GET /space_jam/_search
{
  "query": {
    "match": {
      "description": "Michael Jordan"
    }
  }
}
```

这个查询将返回所有在`description`字段中包含"Michael Jordan"的文档。

### 搜索结果

Elasticsearch将返回一个包含匹配文档的JSON响应。结果可能如下所示:

```json
{
  "took": 1,
  "timed_out": false,
  "_shards": {
    "total": 1,
    "successful": 1,
    "skipped": 0,
    "failed": 0
  },
  "hits": {
    "total": {
      "value": 1,
      "relation": "eq"
    },
    "max_score": 2.8477805,
    "hits": [
      {
        "_index": "space_jam",
        "_type": "_doc",
        "_id": "1",
        "_score": 2.8477805,
        "_source": {
          "title": "Space Jam",
          "description": "Michael Jordan teams up with the Looney Tunes to defeat a group of aliens.",
          "release_date": "1996-11-15",
          "director": "Joe Pytka"
        }
      }
    ]
  }
}
```

这个响应显示了搜索查询找到了一个匹配的文档,并且提供了文档的得分和原始内容。

通过这个"SpaceJam"的实例,我们可以看到Elasticsearch如何用于全文搜索,包括创建索引、定义映射、索引文档以及执行搜索查询。


http://www.ppmy.cn/news/1470437.html

相关文章

计算机网络:网络层 - 虚拟专用网 VPN 网络地址转换 NAT

计算机网络:网络层 - 虚拟专用网 VPN & 网络地址转换 NAT 专用地址与全球地址虚拟专用网 VPN隧道技术 网络地址转换 NAT网络地址与端口号转换 NAPT 专用地址与全球地址 考虑到 IP 地址的紧缺,以及某些主机只需要和本机构内部的其他主机进行通信&…

【AIOps】基于AIOps的故障根因分析及定位

基础知识: 基于机器学习的异常检测与分析技术 传统做法: 复杂运维场景下,如何实现分钟级的故障根因定位 结合大模型: 基于大语言模型的云故障根因分析|顶会EuroSys24论文

【Python日志模块全面指南】:记录每一行代码的呼吸,掌握应用程序的脉搏

文章目录 🚀一、了解日志🌈二、日志作用🌈三、了解日志模块⭐四、日志级别💥五、记录日志-基础❤️六、记录日志-处理器handler🎬七、记录日志-格式化记录☔八、记录日志-配置logger👊九、流程梳理 &#x…

SpringBoot 多种优雅的线程池配置与使用(异步执行函数,反射机制,动态识别参数,有返回值)

想要明白生活你需要先经历它,而不是总在分析它。 —萨莉鲁尼 文章目录 前言一、@Async注解1. 概念2. 使用2.1 使用@EnableAsync启动函数异步支持2.2 不会异步执行的坑2.2.1 为什么内部调用不会异步执行?2.2.2 如何确保@Async方法异步执行?3. 配置线程池3.1 通过代码配置3.1.…

【经验分享】SpringCloud + MyBatis Plus 配置 MySQL,TDengine 双数据源

概述 因为项目中采集工厂中的设备码点的数据量比较大,需要集成TDengine时序数据库,所以需要设置双数据源 操作步骤 导入依赖 <!-- 多数据源支持 --><dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-s…

宕机了, redis如何保证数据不丢?

前言 如果有人问你&#xff1a;"你会把 Redis 用在什么业务场景下&#xff1f;" 我想你大概率会说&#xff1a;"我会把它当作缓存使用&#xff0c;因为它把后端数据库中的数据存储在内存中&#xff0c;然后直接从内存中读取数据&#xff0c;响应速度会非常快。…

ES的高可用

es最小高可用集群组成 At least three master-eligible nodes&#xff08;至少三个符合主节点条件的节点&#xff09;At least two nodes of each role&#xff08;每个角色至少有两个节点&#xff09;At least two copies of each shard (one primary and one or more replica…

融资A轮B轮是什么意思?

环境&#xff1a; 融资 问题描述&#xff1a; 融资A轮B轮是什么意思 解决方案&#xff1a; 在A轮融资之前&#xff0c;通常有以下几轮融资阶段&#xff1a; 种子轮&#xff08;Seed Round&#xff09;&#xff1a;这是企业生命周期中最早的融资阶段&#xff0c;通常发生在…