欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql大表修改字段兩種解決方式

 更新時間:2024年11月21日 09:21:19   作者:zxc_user  
這篇文章主要給大家介紹了關于Mysql大表修改字段的兩種解決方式,文中介紹了在處理平臺幣訂單表字段類型修改時遇到的問題及解決方案,需要的朋友可以參考下

背景

由于平臺幣需要從之前的整形類型變?yōu)橹С中?shù)的decimal類型,所以需要對訂單表的字段類型進行修改.

訂單表: 目前數(shù)據(jù)已經有 2000多萬數(shù)據(jù)了,數(shù)據(jù)量還是比較大的, 需要修改的字段有3個,訂單表名為 order_info

解決方案一

直接用sql原生語句

alter table order_info MODIFY column coin_count decimal(6, 1);

耗時 500多秒都沒執(zhí)行完, 撤回了,因為鎖表用戶下不了單影響可能還是比較大的,所以該方案廢棄了

解決方案二

用新舊表邏輯進行處理,主要步驟有以下幾步

1: 創(chuàng)建新的表,名字為 order_info_new, 結構從 order_info 復制, 但是那三個字段已經從int改為decimal了, 這個步驟是不會鎖表的

2: 把原有的order_info表名改為 order_info_old, 同時把order_info_new改為 order_info即可,這個步驟也很快,同時也不會鎖表

3: 使用mysql自帶的命令行語句把之前的數(shù)據(jù)遷移到新表中,語句如下,只需要等待完成即可:

INSERT INTO order_info SELECT * FROM order_info_old

注: 第1步建立表時需要注解id的問題,如果是自增的話那么新表的自增id要大一些,防止切換過程中id發(fā)生沖突問題

第三步執(zhí)行時mysql默認是開啟事務的,所以執(zhí)行過程數(shù)據(jù)會查詢不到,需要等到執(zhí)行完成,看有沒有這方面需要考慮的問題

選擇

最終自然是使用了第二種方案咯,整個過程也不算太慢,2000多萬數(shù)據(jù)遷移也就用了半個多小時,阿里的RDS感覺還是有點東西的應該

其他優(yōu)化

在處理這個問題時,同時一并處理了訂單表設計不合理的地方,主要處理了兩個問題

1: 數(shù)據(jù)字段類型不合理設計

2: 歷史數(shù)據(jù)進行部分遷移

類型優(yōu)化

 `delivery_status` int DEFAULT '1' COMMENT '發(fā)貨狀態(tài) 1:未發(fā)貨 2:已發(fā)貨' 訂單表存在很多這種不合適的字段類型,不合理是因為這個字段只會有2個值,所以應該改為

 `delivery_status` tinyint DEFAULT '1' COMMENT '發(fā)貨狀態(tài) 1:未發(fā)貨 2:已發(fā)貨',這樣比較合理

改完效果還是比較明顯的,一條數(shù)據(jù)就可以節(jié)省3個字節(jié),2000多萬條大概節(jié)省了12G空間出來,這是一件很有意義的事來的

歷史數(shù)據(jù)遷移

order_info的數(shù)據(jù)從 2020年一直到2024年的數(shù)據(jù)都是在同一張表,但其實很多歷史數(shù)據(jù)也不會查了,所以把2020-2021年的數(shù)據(jù)遷移到新的表中去了,做法也很簡單

1: 原來的 order_info 只保留了 2022年以后至今的數(shù)據(jù)

2: 再創(chuàng)建一張 order_info_history 數(shù)據(jù)表,結構一摸一樣的

3: 把 order_info 2022年前的數(shù)據(jù)全部轉到 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;

總結

到此這篇關于Mysql大表修改字段兩種解決方式的文章就介紹到這了,更多相關Mysql大表修改字段內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • CentOS7離線安裝MySQL的教程詳解

    CentOS7離線安裝MySQL的教程詳解

    這篇文章主要介紹了CentOS7離線安裝MySQL的教程,在安裝之前需要我們先刪除原有的mariadb,文中也通過命令給大家介紹了,需要的朋友跟隨小編也看看吧
    2019-07-07
  • MySQL之InnoDB下的鎖問題

    MySQL之InnoDB下的鎖問題

    這篇文章主要介紹了MySQL之InnoDB下的鎖問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL中的SUM函數(shù)使用教程

    MySQL中的SUM函數(shù)使用教程

    這篇文章主要介紹了MySQL中的SUM函數(shù)使用教程,是MySQL入門學習中的基礎知識,需要的朋友可以參考下
    2015-05-05
  • MySQL之七種SQL JOINS實現(xiàn)的圖文詳解

    MySQL之七種SQL JOINS實現(xiàn)的圖文詳解

    這篇文章主要介紹了MySQL中七種SQL JOINS的實現(xiàn)方法及圖文詳解,文中也有相關的代碼示例供大家參考,感興趣的同學可以參考閱讀下
    2023-06-06
  • 在MySQL中使用LIMIT進行分頁的方法

    在MySQL中使用LIMIT進行分頁的方法

    這篇文章主要介紹了在MySQL中使用LIMIT進行分頁的方法,作者列舉出了三種方法,并且針對跳頁等常見問題做出了提示,需要的朋友可以參考下
    2015-05-05
  • SQL?INSERT及批量的幾種方式總結

    SQL?INSERT及批量的幾種方式總結

    SQL提供了INSERT語句,用于將一行或多行插入表中,下面這篇文章主要給大家介紹了關于SQL?INSERT及批量的幾種方式,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • MySQL UDF調試方式debugview的相關方法

    MySQL UDF調試方式debugview的相關方法

    MySQL UDF調試方式debugview的相關方法...
    2007-07-07
  • mysql中workbench實例詳解

    mysql中workbench實例詳解

    在本篇文章里小編給大家分享了關于mysql中workbench實例內容,有興趣的朋友們學習下。
    2019-01-01
  • 基于MySQL游標的具體使用詳解

    基于MySQL游標的具體使用詳解

    本篇文章是對MySQL游標的具體使用進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • mysql字符串拼接的幾種實用方式小結

    mysql字符串拼接的幾種實用方式小結

    在SQL語句中經常需要進行字符串拼接,下面這篇文章主要給大家介紹了關于mysql字符串拼接的幾種實用方式,文中通過圖文以及代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-11-11

最新評論