Mysql大表修改字段兩種解決方式
背景
由于平臺(tái)幣需要從之前的整形類型變?yōu)橹С中?shù)的decimal類型,所以需要對(duì)訂單表的字段類型進(jìn)行修改.
訂單表: 目前數(shù)據(jù)已經(jīng)有 2000多萬數(shù)據(jù)了,數(shù)據(jù)量還是比較大的, 需要修改的字段有3個(gè),訂單表名為 order_info
解決方案一
直接用sql原生語句
alter table order_info MODIFY column coin_count decimal(6, 1);
耗時(shí) 500多秒都沒執(zhí)行完, 撤回了,因?yàn)殒i表用戶下不了單影響可能還是比較大的,所以該方案廢棄了
解決方案二
用新舊表邏輯進(jìn)行處理,主要步驟有以下幾步
1: 創(chuàng)建新的表,名字為 order_info_new, 結(jié)構(gòu)從 order_info 復(fù)制, 但是那三個(gè)字段已經(jīng)從int改為decimal了, 這個(gè)步驟是不會(huì)鎖表的
2: 把原有的order_info表名改為 order_info_old, 同時(shí)把order_info_new改為 order_info即可,這個(gè)步驟也很快,同時(shí)也不會(huì)鎖表
3: 使用mysql自帶的命令行語句把之前的數(shù)據(jù)遷移到新表中,語句如下,只需要等待完成即可:
INSERT INTO order_info SELECT * FROM order_info_old
注: 第1步建立表時(shí)需要注解id的問題,如果是自增的話那么新表的自增id要大一些,防止切換過程中id發(fā)生沖突問題
第三步執(zhí)行時(shí)mysql默認(rèn)是開啟事務(wù)的,所以執(zhí)行過程數(shù)據(jù)會(huì)查詢不到,需要等到執(zhí)行完成,看有沒有這方面需要考慮的問題
選擇
最終自然是使用了第二種方案咯,整個(gè)過程也不算太慢,2000多萬數(shù)據(jù)遷移也就用了半個(gè)多小時(shí),阿里的RDS感覺還是有點(diǎn)東西的應(yīng)該
其他優(yōu)化
在處理這個(gè)問題時(shí),同時(shí)一并處理了訂單表設(shè)計(jì)不合理的地方,主要處理了兩個(gè)問題
1: 數(shù)據(jù)字段類型不合理設(shè)計(jì)
2: 歷史數(shù)據(jù)進(jìn)行部分遷移
類型優(yōu)化
`delivery_status` int DEFAULT '1' COMMENT '發(fā)貨狀態(tài) 1:未發(fā)貨 2:已發(fā)貨' 訂單表存在很多這種不合適的字段類型,不合理是因?yàn)檫@個(gè)字段只會(huì)有2個(gè)值,所以應(yīng)該改為
`delivery_status` tinyint DEFAULT '1' COMMENT '發(fā)貨狀態(tài) 1:未發(fā)貨 2:已發(fā)貨',這樣比較合理
改完效果還是比較明顯的,一條數(shù)據(jù)就可以節(jié)省3個(gè)字節(jié),2000多萬條大概節(jié)省了12G空間出來,這是一件很有意義的事來的
歷史數(shù)據(jù)遷移
order_info的數(shù)據(jù)從 2020年一直到2024年的數(shù)據(jù)都是在同一張表,但其實(shí)很多歷史數(shù)據(jù)也不會(huì)查了,所以把2020-2021年的數(shù)據(jù)遷移到新的表中去了,做法也很簡單
1: 原來的 order_info 只保留了 2022年以后至今的數(shù)據(jù)
2: 再創(chuàng)建一張 order_info_history 數(shù)據(jù)表,結(jié)構(gòu)一摸一樣的
3: 把 order_info 2022年前的數(shù)據(jù)全部轉(zhuǎn)到 order_info_history 中
具體的操作命令如下:
INSERT INTO order_info SELECT * FROM order_info_old where create_time >= 1640966400000; INSERT INTO order_info_history SELECT * FROM order_info_old where create_time < 1640966400000;
總結(jié)
到此這篇關(guān)于Mysql大表修改字段兩種解決方式的文章就介紹到這了,更多相關(guān)Mysql大表修改字段內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL之七種SQL JOINS實(shí)現(xiàn)的圖文詳解
這篇文章主要介紹了MySQL中七種SQL JOINS的實(shí)現(xiàn)方法及圖文詳解,文中也有相關(guān)的代碼示例供大家參考,感興趣的同學(xué)可以參考閱讀下2023-06-06MySQL UDF調(diào)試方式debugview的相關(guān)方法
MySQL UDF調(diào)試方式debugview的相關(guān)方法...2007-07-07