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

MySQL 8.0 Online DDL快速加列的相關(guān)總結(jié)

 更新時間:2021年06月01日 11:20:45   作者:DBA隨筆  
在實(shí)際的MySQL運(yùn)維過程中,我們經(jīng)常會遇到業(yè)務(wù)需要給某張表添加字段的情況,本文將介紹幾種加字段的方法,感興趣的朋友可以參考下

問題描述

前幾天同事問了我一個問題:業(yè)務(wù)A從MySQL遷移到MongoDB的原因是什么?

說實(shí)話,這個問題還真不好回答,為什么要遷移,一定是遇到了某種瓶頸,可能是數(shù)據(jù)量也可能是數(shù)據(jù)類型等,于是我咨詢了一下業(yè)務(wù),最終得到了答案:這個業(yè)務(wù)中的某些表,要頻繁的加字段。mongodb中加字段的成本幾乎沒有,而MySQL低版本中加字段的成本還是挺高的。

那么常用的MySQL添加字段的方法有哪些呢?這里我簡單列舉一下:

1、percona的pt-osc工具

2、github開源項(xiàng)目gh-ost工具

3、MySQL原生Online DDL

MySQL Online DDL加列的歷史方法

01 Copy方法

MySQL5.5版本及之前的加列方法:Copy

它的執(zhí)行示意圖如下:

我們有一個原表A,只包含1個字段,它包含1、2、4、6這幾條記錄,當(dāng)我們使用Copy算法加列時:

1、創(chuàng)建了一個新的表tmp-A,新表包含2個字段,

2、然后我們把表A的數(shù)據(jù)全部逐行拷貝到tmp-A這個新表里面,

3、然后用tmp-A表和A表做個交換,

    這樣,我們的新表就包含2個字段了。同時需要注意,新表中的數(shù)據(jù)記錄比原表更加緊湊了。原表中可能由于刪除了3和5兩條記錄,使得表中間留下了空洞,或者叫空間碎片。

    可以看到,Copy算法需要拷貝一遍數(shù)據(jù),需要額外的存儲空間來存儲tmp-A這個臨時表。另外,在拷貝數(shù)據(jù)的過程中,表A的寫入操作會丟失,也就是說,表A在alter table的過程中不能有數(shù)據(jù)更新。這可能是一個致命的缺點(diǎn)。

02 Inplace方法

MySQL5.6版本開始引入Online DDL,這個功能使得上面的過程變成了下面這樣:

 它的過程和上面的Copy算法有些不同:

1、Online DDL過程中,從表A提取B+樹,并存儲到一個中間文件tmp-file,而不是中間表tmp-A

2、步驟1執(zhí)行過程中,對表A的寫入,都會記錄到row log中

3、步驟1執(zhí)行完畢后,對tmp-file應(yīng)用所有的row log,得到一個與表A數(shù)據(jù)相同的數(shù)據(jù)文件

4、利用數(shù)據(jù)文件tmp-file替換表A的數(shù)據(jù)文件即可。

    這個過程中,由于row log的存在,使得在整個該表過程中,表A是可以進(jìn)行增刪改查的操作的,因?yàn)檫@些操作不會丟失。這也就是為什么把這個過程叫做Online DDL的原因。

    另外,這里需要解釋下,Copy算法中生成的tmp-A臨時表是在Server層面創(chuàng)建的,而上述Online DDL操作中的tmp-file是在插件式存儲引擎Innodb內(nèi)部生成的,我們把這種在Innodb內(nèi)部完成的變更操作,稱之為Inplace(中文表示原地),也就是不需要將數(shù)據(jù)挪動到"server層的臨時表"。

MySQL8.0.12 引入的Instant方法

    MySQL8.0.12版本引入了Instant的方法,它讓加列變得更加簡單。instant算法添加列時不再需要 rebuild 整個表,只需要在表的 metadata 中記錄新增列的基本信息即可。

    我們來看它的優(yōu)勢,首先我們創(chuàng)建一個表t1,并插入26w條數(shù)據(jù),然后分別添加數(shù)據(jù)列col_1,col_2,col_3,并顯示指定加列的算法為copy、inplace、和instant,結(jié)果如下:

 [test] 23:42:45> select count(1) from t1;
 +----------+
 | count(1) |
 +----------+
 |   262144 |
 +----------+
 1 row in set (0.06 sec)
 
方案一:copy
[test] 23:43:29> alter table t1 add col_1 int,algorithm=copy;  
Query OK, 262144 rows affected (1.48 sec)
Records: 262144  Duplicates: 0  Warnings: 0

方案二:inplace
[test] 23:43:46> alter table t1 add col_2 int,algorithm=inplace; 
Query OK, 0 rows affected (0.58 sec)
Records: 0  Duplicates: 0  Warnings: 0

方案三:instant
[test] 23:44:08> alter table t1 add col_3 int,algorithm=instant; 
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

m5480:mysqlha_common@10.41.28.124 [test] 23:44:14> show create table t1\G
*************************** 1. row ***************************
       Table: t1
Create Table: CREATE TABLE `t1` (
  `id` int NOT NULL AUTO_INCREMENT,
  `name` varchar(10) COLLATE utf8mb4_general_ci DEFAULT NULL,
  `age` int DEFAULT NULL,
  `score` int DEFAULT NULL,
  `col_1` int DEFAULT NULL,
  `col_2` int DEFAULT NULL,
  `col_3` int DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `idx_sco` (`score`)
) ENGINE=InnoDB AUTO_INCREMENT=458730 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci
1 row in set (0.01 sec)

   從結(jié)果不難看出,執(zhí)行時間上:

copy> inplace > instant

與此同時,copy算法的受影響行數(shù)是全部表,而inplace和instant的算法影響的行數(shù)都是0,說明他們是Online DDL操作。 

    最后,我們還可以通過下面的方法查看instant列的信息:

[test] 23:53:01> SELECT * FROM information_schema.innodb_tables where name like 'test/t1'\G
 *************************** 1. row ***************************
      TABLE_ID: 1079
          NAME: test/t1
          FLAG: 33
        N_COLS: 10
         SPACE: 22
    ROW_FORMAT: Dynamic
 ZIP_PAGE_SIZE: 0
   SPACE_TYPE: Single
 INSTANT_COLS: 6
1 row in set (0.00 sec)

    可以看到,test.t1這個表的instant列序號是6,代表它是這個表的第7個列(列編號從0開始)。

    當(dāng)然,instant算法不支持刪除普通列、無法設(shè)置列的順序、還有一些其他的限制,詳情可以查看官方文檔:https://dev.mysql.com/doc/refman/8.0/en/innodb-online-ddl-operations.html

    但這些限制并不影響它成為一個優(yōu)秀的DDL功能。 相信通過MySQL版本的不斷迭代,在后面的版本中,有更多的變更操作可以用到instant這種高效的算法。

以上就是MySQL 8.0 Online DDL快速加列的相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于MySQL DDL快速加列的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • mysql中的replace函數(shù)替換字符串問題

    mysql中的replace函數(shù)替換字符串問題

    這篇文章主要介紹了mysql中的replace函數(shù)替換字符串問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • MySQL中varchar(n) 中n最大取值為多少

    MySQL中varchar(n) 中n最大取值為多少

    本文主要介紹了MySQL中varchar(n) 中n最大取值為多少
    2024-08-08
  • MySQL的邏輯架構(gòu)及工作全流程

    MySQL的邏輯架構(gòu)及工作全流程

    這篇文章主要介紹了MySQL的邏輯架構(gòu)及工作全流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • mysql實(shí)現(xiàn)查詢最接近的記錄數(shù)據(jù)示例

    mysql實(shí)現(xiàn)查詢最接近的記錄數(shù)據(jù)示例

    這篇文章主要介紹了mysql實(shí)現(xiàn)查詢最接近的記錄數(shù)據(jù),涉及mysql查詢相關(guān)的時間轉(zhuǎn)換、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07
  • MySQL實(shí)現(xiàn)批量插入以優(yōu)化性能的教程

    MySQL實(shí)現(xiàn)批量插入以優(yōu)化性能的教程

    這篇文章主要介紹了MySQL實(shí)現(xiàn)批量插入以優(yōu)化性能的教程,文中給出了運(yùn)行時間來表示性能優(yōu)化后的對比,需要的朋友可以參考下
    2015-04-04
  • Mysql數(shù)據(jù)庫之Binlog日志使用總結(jié)(必看篇)

    Mysql數(shù)據(jù)庫之Binlog日志使用總結(jié)(必看篇)

    下面小編就為大家?guī)硪黄狹ysql數(shù)據(jù)庫之Binlog日志使用總結(jié)(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • MySQL使用LVM快照實(shí)現(xiàn)備份

    MySQL使用LVM快照實(shí)現(xiàn)備份

    本文給大家詳細(xì)的說明了使用LVM快照的方式來為Mysql制作備份的方法和步驟,有需要的小伙伴可以參考下
    2016-11-11
  • Window環(huán)境下MySQL?UDF提權(quán)

    Window環(huán)境下MySQL?UDF提權(quán)

    本文章僅記錄某次內(nèi)網(wǎng)滲透過程中遇到的MySQL?采用UDF提權(quán)等方式進(jìn)行獲取權(quán)限,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2023-03-03
  • 淺析MySQL如何實(shí)現(xiàn)事務(wù)隔離

    淺析MySQL如何實(shí)現(xiàn)事務(wù)隔離

    使用過關(guān)系型數(shù)據(jù)庫的,應(yīng)該都事務(wù)的概念有所了解,知道事務(wù)有 ACID 四個基本屬性:原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)和持久性(Durability),今天我們主要來理解一下事務(wù)的隔離性
    2021-06-06
  • 深入了解MySQL中的慢查詢

    深入了解MySQL中的慢查詢

    什么是MySQL慢查詢呢?其實(shí)就是查詢的SQL語句耗費(fèi)較長的時間。具體耗費(fèi)多久算慢查詢呢?這其實(shí)因人而異,有些公司慢查詢的閾值是100ms,有些的閾值可能是500ms。本文將通過示例和大家聊聊慢查詢的危害和常用場景,感興趣的可以了解一下
    2022-10-10

最新評論