日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL 8.0 Online DDL快速加列的相關總結

瀏覽:28日期:2023-10-02 12:30:22
目錄問題描述MySQL Online DDL加列的歷史方法01 Copy方法02 Inplace方法MySQL8.0.12 引入的Instant方法問題描述

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

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

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

1、percona的pt-osc工具

2、github開源項目gh-ost工具

3、MySQL原生Online DDL

MySQL Online DDL加列的歷史方法01 Copy方法

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

它的執行示意圖如下:

MySQL 8.0 Online DDL快速加列的相關總結

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

1、創建了一個新的表tmp-A,新表包含2個字段,

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

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

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

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

02 Inplace方法

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

MySQL 8.0 Online DDL快速加列的相關總結

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

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

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

3、步驟1執行完畢后,對tmp-file應用所有的row log,得到一個與表A數據相同的數據文件

4、利用數據文件tmp-file替換表A的數據文件即可。

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

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

MySQL8.0.12 引入的Instant方法

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

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

[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: 0m5480:mysqlha_common@10.41.28.124 [test] 23:44:14> show create table t1G*************************** 1. row *************************** Table: t1Create 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_ci1 row in set (0.01 sec)

從結果不難看出,執行時間上:

copy> inplace > instant

與此同時,copy算法的受影響行數是全部表,而inplace和instant的算法影響的行數都是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: 33N_COLS: 10 SPACE: 22 ROW_FORMAT: Dynamic ZIP_PAGE_SIZE: 0 SPACE_TYPE: Single INSTANT_COLS: 61 row in set (0.00 sec)

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

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

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

以上就是MySQL 8.0 Online DDL快速加列的相關總結的詳細內容,更多關于MySQL DDL快速加列的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲成人日韩| 免费污视频在线一区| 亚洲精品1区| 欧美色图一区| 欧美手机在线| 亚洲神马久久| 亚洲婷婷丁香| 日韩国产在线一| 97久久亚洲| 国产视频网站一区二区三区| 久久国产乱子精品免费女| 国产精品一区二区精品| 麻豆成人91精品二区三区| 久久99高清| 伊人网在线播放| 久久中文亚洲字幕| 亚洲一区国产一区| 丝瓜av网站精品一区二区| 久久先锋影音| 日韩福利视频网| 欧美国产亚洲精品| av中文字幕在线观看第一页| 欧美一区二区三区高清视频| 国产精品毛片| 青青草精品视频| 电影91久久久| 香蕉精品视频在线观看| 日日摸夜夜添夜夜添国产精品| 国产精品久久777777毛茸茸| 日本不卡免费高清视频在线| 一区视频在线| 欧美日本精品| 麻豆mv在线观看| 在线亚洲观看| 国产欧美日韩在线观看视频| se01亚洲视频| 亚洲精品激情| 国产精品成人a在线观看| 婷婷综合在线| 日韩高清三区| 日本激情一区| 热久久免费视频| 国产精成人品2018| 久久精品高清| 日韩精品久久久久久久软件91| 国产伊人久久| 99国产精品视频免费观看一公开| 亚洲精品麻豆| 日本美女一区| 涩涩涩久久久成人精品| 精品久久免费| 日韩精品一二三区| 四季av一区二区凹凸精品| 羞羞答答国产精品www一本| 国产精品主播在线观看| 影视先锋久久| 久久国产尿小便嘘嘘| 极品裸体白嫩激情啪啪国产精品| 欧美亚洲二区| 在线一区免费| 久久精品国产999大香线蕉| 99re国产精品| 欧美激情福利| 香蕉久久久久久久av网站| 久久一区精品| 综合色就爱涩涩涩综合婷婷| 日韩精品dvd| 久久国产三级精品| 日韩一级欧洲| av综合电影网站| 日韩福利视频导航| 红桃视频欧美| 色网在线免费观看| 国产精品综合色区在线观看| 亚洲综合日本| 欧美成人a交片免费看| 日本午夜精品一区二区三区电影| 99精品在线| 久久三级中文| 国产日产精品_国产精品毛片| 波多野结衣一区| 国产一区丝袜| 久久国产视频网| 亚洲影视一区二区三区| 久久精品青草| 精品欠久久久中文字幕加勒比| 亚洲一级淫片| 国产精品7m凸凹视频分类| 国产一区二区三区黄网站| 日韩不卡一区二区三区 | 久久久久一区| 麻豆久久久久久| 日韩av中文字幕一区二区| 免费久久精品| 午夜精品成人av| 精品国产中文字幕第一页| 婷婷综合福利| 一级欧美视频| 老司机久久99久久精品播放免费| 久久久天天操| 蜜臀国产一区| 国产精品久久久久蜜臀| 美女av一区| 97精品资源在线观看| 在线观看一区| 欧美精选一区二区三区| 91精品综合| 日韩欧美精品一区| 国产一区二区精品久| 久久影院资源站| 欧美黄色精品| 国产精品一线| 欧美日韩夜夜| 国产日韩欧美中文在线| 日韩福利视频网| 久久国产尿小便嘘嘘| 国产欧美三级| 欧美激情五月| 精品一区二区三区中文字幕在线| 国产欧美亚洲一区| 国产精品毛片aⅴ一区二区三区| 91亚洲无吗| 国产欧美日韩免费观看| 国产探花在线精品| 国产精品66| 久久精品国产精品亚洲毛片| 精品久久精品| 国产欧美二区| 久久精品一本| 新版的欧美在线视频| 国产精品成人a在线观看| 另类专区亚洲| 亚洲黑丝一区二区| 波多野结衣一区| 美女久久网站| 亚洲视频国产| 97精品久久| 精品久久网站| 国产99精品| 亚洲一区二区三区高清不卡| 蜜臀va亚洲va欧美va天堂| 最新国产精品久久久| 日韩国产成人精品| 精品视频一区二区三区四区五区| 国产精品99久久精品| 宅男在线一区| 香蕉久久一区| 久久亚洲精品中文字幕| 久久久久久黄| 免费成人性网站| 中文字幕成人| 国产欧美69| 伊人久久在线| 亚洲欧美日本国产专区一区| 亚洲欧美久久精品| 久久久精品区| 欧美va天堂在线| 亚洲三级毛片| 开心激情综合| 99精品电影| 日本免费在线视频不卡一不卡二| 久久影视三级福利片| 亚洲成人国产| 深夜福利一区| 精品视频亚洲| 亚洲高清成人| 日韩一区中文| 国产成人黄色| 在线视频免费在线观看一区二区| 日韩国产精品久久久| 色婷婷色综合| 蜜桃视频在线观看一区| 国产精品a级| 欧洲毛片在线视频免费观看| 日韩和欧美一区二区三区| 97精品国产| 蜜桃av一区二区在线观看| 久久久亚洲欧洲日产| 日韩午夜一区| 麻豆精品在线视频| 91一区二区| 蜜桃久久精品一区二区| 精品国产鲁一鲁****| 99xxxx成人网| 老司机免费视频一区二区三区| 好看的av在线不卡观看| 国产精品大片| 国产模特精品视频久久久久| 麻豆精品在线观看| 久久国产精品久久w女人spa| 麻豆国产欧美日韩综合精品二区| 制服诱惑一区二区| 精品一区不卡| 中文字幕免费精品| 日韩av免费| 欧美日韩亚洲一区二区三区在线| 夜鲁夜鲁夜鲁视频在线播放| 69堂精品视频在线播放| 激情五月综合| 超级白嫩亚洲国产第一|