ES修改字段類型的操作方式
一、需求概述
ES修改字段類型是指在已有的索引中,通過(guò)特定的操作方式將某個(gè)字段的類型修改為其它類型。當(dāng)ES在建立索引的時(shí)候,已經(jīng)確定好了每個(gè)字段的類型,而如果在建立后發(fā)現(xiàn)類型不符需求,就需要修改字段類型。
二、修改字段類型的原因
有以下幾種情況會(huì)導(dǎo)致修改字段類型的需求:
1、字段類型選擇錯(cuò)誤:選擇了不合適的字段類型,如字符串類型卻存儲(chǔ)數(shù)字,會(huì)導(dǎo)致查詢結(jié)果出現(xiàn)錯(cuò)誤。
2、業(yè)務(wù)需求變更:隨著業(yè)務(wù)的發(fā)展,需求可能會(huì)發(fā)生變化,需要優(yōu)化現(xiàn)有結(jié)構(gòu)或添加新功能,這就可能需要修改字段類型。
3、數(shù)據(jù)類型不符:ES默認(rèn)的數(shù)據(jù)類型不能滿足業(yè)務(wù)需求,需要自定義類型。
三、修改字段類型的操作方式
修改字段類型主要有以下兩種方式:
1、使用Reindex API:Reindex API可以將已有索引中的數(shù)據(jù)重新建立索引到新的索引中,同時(shí)可以修改字段類型。
2、使用Update by Query API:Update by Query API可以指定需要修改的字段類型,更新指定字段的數(shù)據(jù)。
四、修改字段類型的具體實(shí)現(xiàn)
1、使用Reindex API
Reindex API實(shí)現(xiàn)字段類型修改的具體流程如下:
1)建立新的索引并指定需要修改的字段類型。
PUT /new_index { "mappings": { "properties": { "new_field": { "type": "integer" } } } }
2)使用Reindex API將舊索引的數(shù)據(jù)重新建立索引到新的索引中,同時(shí)修改字段類型。
POST _reindex { "source": { "index": "old_index" }, "dest": { "index": "new_index" }, "script": { "source": "ctx._source.new_field=ctx._source.old_field", "lang": "painless" } }
2、使用Update by Query API
Update by Query API實(shí)現(xiàn)字段類型修改的具體流程如下:
1)使用Update by Query API指定需要修改的字段類型。
POST old_index/_update_by_query { "script": { "source": "ctx._source.new_field=params.new_field", "params": { "new_field": { "type": "integer" } } } }
五、注意事項(xiàng)
1、修改字段類型可能會(huì)影響查詢結(jié)果,需要在業(yè)務(wù)允許的情況下進(jìn)行修改。
2、修改字段類型的過(guò)程中需要保證數(shù)據(jù)的一致性和完整性。
3、如果使用Reindex API,需要保證新索引和舊索引的映射關(guān)系一致,否則可能會(huì)導(dǎo)致數(shù)據(jù)丟失。
4、如果數(shù)據(jù)量非常大,建議使用scroll API逐步遷移。
到此這篇關(guān)于ES修改字段類型詳解的文章就介紹到這了,更多相關(guān)ES修改字段類型內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IDEA SpringBoot:Cannot resolve configuration&
這篇文章主要介紹了IDEA SpringBoot:Cannot resolve configuration property配置文件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07springboot快速集成mybatis-plus的詳細(xì)教程
這篇文章主要介紹了springboot快速集成mybatis-plus的教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09springboot?vue項(xiàng)目管理前后端實(shí)現(xiàn)編輯功能
這篇文章主要為大家介紹了springboot?vue項(xiàng)目管理前后端實(shí)現(xiàn)編輯功能,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Java8?Stream?collect(Collectors.toMap())的使用
這篇文章主要介紹了Java8?Stream?collect(Collectors.toMap())的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05解析springBoot-actuator項(xiàng)目構(gòu)造中health端點(diǎn)工作原理
這篇文章主要介紹了springBoot-actuator中health端點(diǎn)工作原理,對(duì)spring-boot-actuator的項(xiàng)目構(gòu)造,工作原理進(jìn)行了全面的梳理,側(cè)重health健康檢查部分2022-02-02java根據(jù)List內(nèi)對(duì)象的屬性排序方法
下面小編就為大家分享一篇java根據(jù)List內(nèi)對(duì)象的屬性排序方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01StringUtils中的isEmpty、isNotEmpty、isBlank和isNotBlank的區(qū)別詳解
這篇文章主要介紹了StringUtils中的isEmpty、isNotEmpty、isBlank和isNotBlank的區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06springboot+vue制作后臺(tái)管理系統(tǒng)項(xiàng)目
本文詳細(xì)介紹了后臺(tái)管理使用springboot+vue制作,以分步驟、圖文的形式詳細(xì)講解,大家有需要的可以參考參考2021-08-08簡(jiǎn)單講解在Java編程中實(shí)現(xiàn)設(shè)計(jì)模式中的單例模式結(jié)構(gòu)
這篇文章主要介紹了簡(jiǎn)單講解在Java編程中實(shí)現(xiàn)設(shè)計(jì)模式中的單例模式結(jié)構(gòu),設(shè)計(jì)模式是最基本直白簡(jiǎn)單的一種設(shè)計(jì)模式,需要的朋友可以參考下2016-04-04