ElasticSearch备考 -- Multi field

一、题目

Create the index `hamlet_2` with one primary shard and no replicas

Copy the mapping of `hamlet_1` into `hamlet_2`, but also define a multi-field for `speaker`. The name of such multi-field is `tokens` and its data type is the (default) analysed string

Reindex `hamlet_1` to `hamlet_2`

`hamlet_1` index mapping

{

"line_number": "text",

"speaker": "text",

"text_entry": "text"

}

Verify that full-text queries on "speaker.tokens" are enabled on `hamlet_2` by running the following command:

GET hamlet_2/_search

{

"query": {

"match": { "speaker.tokens": "hamlet" }

}

}

二、思考

我们来分析一下题目的要求,其中说要求拷贝`hamlet_1`mapping定义,并且要求顶一个的多字段类型speaker,其中一个字段名字叫tokenle,类型为文本类型。

多字段其实主要考察mapping的自定义,我们可以理解为一个字段有多种类型,是通过fields关键字段实现。

三、解题

Step 1、创建 `hamlet_1` mapping

bash 复制代码
PUT /hamlet_1
{
  "mappings": {
    "properties": {
      "line_number": {
        "type": "text"
      },
      "speaker": {
        "type": "text"
      },
      "text_entry": {
        "type": "text"
      }
    }
  }

Step 2、拷贝索引hamlet_1结构创建hamlet_2索引

索引中settings 配置

  • number_of_shards:索引分片数量
  • number_of_replicas:索引中备份数量

多字段要使用fileds 关键字,定义字段和mapping中最外层字段定义一样

bash 复制代码
PUT /hamlet_2
{
  "settings": {
    "number_of_shards": 1,
    "number_of_replicas": 0
  },
  "mappings": {
    "properties": {
      "line_number": {
        "type": "text"
      },
      "speaker": {
        "type": "text",
        "fields": {
          "token": {
            "type": "text"
          }
        }
      },
      "text_entry": {
        "type": "text"
      }
    }
  }
}

Step 3、reindex 数据

bash 复制代码
POST _reindex
{
  "source": {
    "index": "hamlet_1"
  },
  "dest": {
    "index": "hamlet_2"
  }
}

Step 4、执行查询

bash 复制代码
GET hamlet_2/_search
{
  "query": {
    "match": {
      "speaker.tokens": "hamlet"
    }
  }
}

四、总结

mapping中多字段定义要是使用关键字 fileds,创建字段和最外层字段格式一样

参考资料

送一波福利:

福利一

有需要内推JD的同学,可以私信或留言,我帮您内推,流程快!!!

有需要内推JD的同学,可以私信或留言,我帮您内推,流程快!!!

有需要内推JD的同学,可以私信或留言,我帮您内推,流程快!!!

福利二

福利三

相关推荐
小鹿撞出了脑震荡8 分钟前
SQLite3语句以及用实现FMDB数据存储的学习
数据库·学习·sqlite
infiniteWei8 分钟前
【Lucene】搜索引擎和文档相关性评分 BM25 算法的工作原理
算法·搜索引擎·lucene
lcintj16 分钟前
【WPF】Prism学习(九)
学习·wpf·prism
一只小菜鸡..39 分钟前
241121学习日志——[CSDIY] [InternStudio] 大模型训练营 [11]
学习
2402_871321951 小时前
MATLAB方程组
gpt·学习·线性代数·算法·matlab
那一抹阳光多灿烂1 小时前
Spark中的Stage概念
大数据·spark
2301_775281191 小时前
法语旅游常用口语-柯桥学外语到蓝天广场泓畅学校
学习·生活·旅游
SSL_lwz1 小时前
P11290 【MX-S6-T2】「KDOI-11」飞船
c++·学习·算法·动态规划
北京鹏生科技有限公司2 小时前
EcoVadis审核是什么?EcoVadis审核流程包括什么?
大数据·百度