ElasticSearch7.x版本更新映射字段

2024-04-27 20:20

本文主要是介绍ElasticSearch7.x版本更新映射字段,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、新建索引

请求方式:PUT

请求URL:

2、数据迁移

请求方式:POST

请求URL:

请求体:

3、验证新索引

请求方式:GET

请求URL:

响应体:

4、删除旧索引

请求方式:DELETE

请求URL:

5、新建旧索引

请求方式:PUT

请求URL:

5、再次数据迁移

请求方式:POST

请求URL:

 请求体:

6、再次验证

请求方式:GET

请求URL:

数据验证:

现有索引:testold

{"testold": {"aliases": {},"mappings": {"properties": {"_class": {"type": "text","fields": {"keyword": {"type": "keyword","ignore_above": 256}}},"id": {"type": "keyword"},"cotent": {"type": "keyword"},"tid": {"type": "keyword"}}},"settings": {"index": {"creation_date": "1713842844859","number_of_shards": "1","number_of_replicas": "1","uuid": "YmaRFkrmR-SuD-V95VpmwQ","version": {"created": "7090099"},"provided_name": "testold"}}}
}

工具人索引:testnew

{"mappings": {"properties": {"cotent": {"type": "keyword"}, "id": {"type": "keyword"}, "tid": {"type": "long"}}}, "settings": {"index": {"number_of_shards": 1, "number_of_replicas": 1}}
}

需要把testold的tid字段修改为long类型。

1、新建索引

请求方式:PUT

请求URL:

http://localhost:9200/testnew

{"mappings": {"properties": {"cotent": {"type": "keyword"}, "id": {"type": "keyword"}, "tid": {"type": "long"}}}, "settings": {"index": {"number_of_shards": 1, "number_of_replicas": 1}}
}

2、数据迁移

请求方式:POST

请求URL:

http://localhost:9200/_reindex

请求体:

{"source": {"index": "testold"}, "dest": {"index": "testnew"}
}

3、验证新索引

请求方式:GET

请求URL:

http://localhost:9200/testnew/_mapping

响应体:

{"testnew": {"aliases": { }, "mappings": {"properties": {"_class": {"type": "text", "fields": {"keyword": {"type": "keyword", "ignore_above": 256}}}, "id": {"type": "keyword"}, "cotent": {"type": "keyword"}, "tid": {"type": "long"}}}, "settings": {"index": {"creation_date": "1713842844859", "number_of_shards": "1", "number_of_replicas": "1", "uuid": "YmaRFkrmR-SuD-V95VpmwQ", "version": {"created": "7090145"}, "provided_name": "testnew"}}}
}

4、删除旧索引

请求方式:DELETE

请求URL:

http://localhost:9200/testold

注意:删除旧索引后,需要按照新要求的字段类型进行新建

5、新建旧索引

使用旧的索引名进行新建,以上动作目的是保证数据不丢失。

请求方式:PUT

请求URL:

http://localhost:9200/testold

{"mappings": {"properties": {"cotent": {"type": "keyword"}, "id": {"type": "keyword"}, "tid": {"type": "long"}}}, "settings": {"index": {"number_of_shards": 1, "number_of_replicas": 1}}
}

5、再次数据迁移

请求方式:POST

请求URL:

http://localhost:9200/_reindex

 请求体:

{"source": {"index": "testnew"}, "dest": {"index": "testold"}
}

6、再次验证

请求方式:GET

请求URL:

http://localhost:9200/testold/_mapping

数据验证:

http://localhost:9200/testold/_search

总结:在整个过程中,testnew只是祈祷一个中间过度的作用,确保在修改字段类型的过程中造成的数据丢失问题。

这篇关于ElasticSearch7.x版本更新映射字段的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/941448

相关文章

golang1.23版本之前 Timer Reset方法无法正确使用

《golang1.23版本之前TimerReset方法无法正确使用》在Go1.23之前,使用`time.Reset`函数时需要先调用`Stop`并明确从timer的channel中抽取出东西,以避... 目录golang1.23 之前 Reset ​到底有什么问题golang1.23 之前到底应该如何正确的

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

Debian如何查看系统版本? 7种轻松查看Debian版本信息的实用方法

《Debian如何查看系统版本?7种轻松查看Debian版本信息的实用方法》Debian是一个广泛使用的Linux发行版,用户有时需要查看其版本信息以进行系统管理、故障排除或兼容性检查,在Debia... 作为最受欢迎的 linux 发行版之一,Debian 的版本信息在日常使用和系统维护中起着至关重要的作

Linux Mint Xia 22.1重磅发布: 重要更新一览

《LinuxMintXia22.1重磅发布:重要更新一览》Beta版LinuxMint“Xia”22.1发布,新版本基于Ubuntu24.04,内核版本为Linux6.8,这... linux Mint 22.1「Xia」正式发布啦!这次更新带来了诸多优化和改进,进一步巩固了 Mint 在 Linux 桌面

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

什么是 Ubuntu LTS?Ubuntu LTS和普通版本区别对比

《什么是UbuntuLTS?UbuntuLTS和普通版本区别对比》UbuntuLTS是Ubuntu操作系统的一个特殊版本,旨在提供更长时间的支持和稳定性,与常规的Ubuntu版本相比,LTS版... 如果你正打算安装 Ubuntu 系统,可能会被「LTS 版本」和「普通版本」给搞得一头雾水吧?尤其是对于刚入