成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

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

說實(shí)話,這個(gè)問題還真不好回答,為什么要遷移,一定是遇到了某種瓶頸,可能是數(shù)據(jù)量也可能是數(shù)據(jù)類型等,于是我咨詢了一下業(yè)務(wù),最終得到了答案:這個(gè)業(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í)行示意圖如下:

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

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

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

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

3、然后用tmp-A表和A表做個(gè)交換,

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

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

02 Inplace方法

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

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

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

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

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

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

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

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

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

MySQL8.0.12 引入的Instant方法

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

我們來看它的優(yōu)勢,首先我們創(chuàng)建一個(gè)表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: 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)

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

copy> inplace > instant

與此同時(shí),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: 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這個(gè)表的instant列序號是6,代表它是這個(gè)表的第7個(gè)列(列編號從0開始)。

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

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

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

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
丝袜美腿高跟呻吟高潮一区| 91精品国产色综合久久| 欧美日韩色综合| 日韩二区三区在线观看| 蜜乳av另类精品一区二区| 中文字幕综合网| 欧美午夜电影在线观看| 亚洲欧洲韩国日本视频| 黑丝一区二区| 亚洲免费在线播放| 国产日产高清欧美一区二区三区| 亚洲黄色在线视频| 国产模特精品视频久久久久| 一区二区三区在线免费视频 | 天天做天天摸天天爽国产一区| 日韩午夜电影| 一区二区三区蜜桃网| 亚洲三级电影在线观看| 亚洲综合小说图片| 久热精品在线| 久久爱另类一区二区小说| 欧美视频一区二区三区| 狠狠色丁香九九婷婷综合五月| 777色狠狠一区二区三区| 国产成人在线视频网址| 久久一夜天堂av一区二区三区| 欧美jjzz| 亚洲三级在线播放| 免费亚洲电影| 久久精品国产网站| 91精品国产免费| 91年精品国产| 国产欧美精品一区二区色综合朱莉| 欧美特黄视频| 亚洲一区二区av电影| 色激情天天射综合网| 久久国产生活片100| 欧美一级午夜免费电影| 91欧美激情一区二区三区成人| 久久先锋影音av| 99国产欧美另类久久久精品| 国产精品亲子乱子伦xxxx裸| 国产一区二区高清| 男人的j进女人的j一区| 日韩视频一区在线观看| 欧美日产一区二区三区在线观看| 一二三四区精品视频| 久热精品视频| 大美女一区二区三区| 国产精品嫩草影院com| 亚洲一区综合| 狠狠久久亚洲欧美| 久久久久99精品国产片| 一区二区三区四区五区精品| 男女视频一区二区| 久久综合九色综合久久久精品综合 | 国产精品一区二区91| 久久亚洲综合av| 激情欧美一区| 日韩av电影天堂| 欧美成人在线直播| 黄色欧美日韩| 日韩国产一区二| www一区二区| 国产精品永久入口久久久| 国产乱人伦精品一区二区在线观看| 国产亚洲一本大道中文在线| 久久av一区二区| 成人黄色在线视频| 亚洲综合精品久久| 日韩欧美国产不卡| 一区二区三区四区五区在线| 激情综合色播五月| 国产欧美精品日韩区二区麻豆天美| 欧美亚洲三区| 99久久99久久精品国产片果冻| 亚洲图片欧美视频| 日韩欧美在线1卡| 国产欧美三级| 成人sese在线| 天堂成人国产精品一区| 久久欧美中文字幕| 性久久久久久| 99精品久久免费看蜜臀剧情介绍| 亚洲国产视频网站| 久久综合网色—综合色88| 久久激情网站| 欧美精品一区在线发布| 美女视频第一区二区三区免费观看网站| 国产日韩成人精品| 欧美日韩午夜在线视频| 亚洲激情国产| 成人免费视频一区| 日本强好片久久久久久aaa| 中文字幕乱码亚洲精品一区| 欧美综合在线视频| 亚洲高清视频一区二区| 国产 日韩 欧美大片| 亚洲成a天堂v人片| 日本一区二区视频在线| 欧美日本乱大交xxxxx| 精品91在线| 成人免费福利片| 午夜精品久久久久久久99樱桃| 久久久久久久久伊人| 老妇喷水一区二区三区| 黄色综合网站| 国产91精品一区二区麻豆网站 | 色综合天天性综合| 免费成人在线播放| 中文字幕在线观看不卡| 欧美一区二区三区四区久久| 亚洲欧美日韩国产综合精品二区| 91亚洲国产成人精品一区二三| 日韩av不卡在线观看| 亚洲三级电影网站| 国产日产欧美一区| 在线91免费看| 欧美日韩高清影院| 国产亚洲毛片在线| 欧美区高清在线| 国产精品18久久久久| 亚洲一区二区三区影院| 精品sm在线观看| 精品视频一区三区九区| 国产精品手机在线| 在线精品在线| 欧美日韩天堂| 99久久婷婷国产| 国产一区不卡精品| 日韩1区2区3区| 亚洲一区二区高清| 中文字幕日本不卡| 日本一区二区三区四区在线视频| 日韩一区二区三区高清免费看看| 91极品视觉盛宴| 久久精品道一区二区三区| 一本色道久久| 91久久极品少妇xxxxⅹ软件| 女人香蕉久久**毛片精品| 丰满亚洲少妇av| 国产成人在线视频播放| 国产一区二区三区在线观看免费视频| 日本人妖一区二区| 三级久久三级久久久| 亚洲午夜免费视频| 亚洲综合久久av| 亚洲女同一区二区| 综合色中文字幕| 中文字幕在线观看一区二区| 欧美国产精品中文字幕| 久久久精品人体av艺术| 久久综合狠狠综合久久激情 | 男男gaygay亚洲| 欧美v亚洲v综合ⅴ国产v| 欧美精品丝袜中出| 欧美日韩在线播放三区四区| 老妇喷水一区二区三区| 久久精品网址| 老司机亚洲精品| 美脚丝袜一区二区三区在线观看| 亚洲一区二区三区精品动漫| 国产精品免费看| 在线亚洲一区| 国产欧美丝祙| 久久黄色网页| 日本高清视频一区二区| 91国偷自产一区二区使用方法| 久久中文精品| 久久精品伊人| 在线免费视频一区二区| 日本韩国欧美国产| 在线一区二区三区四区| 在线观看免费成人| 欧美日韩一区二区三区高清 | 日韩欧美中文字幕精品| 日韩小视频在线观看专区| 精品精品欲导航| 久久综合九色综合欧美98| 337p日本欧洲亚洲大胆精品| 久久久99精品免费观看| 国产欧美日韩三区| 综合久久国产九一剧情麻豆| 亚洲欧美区自拍先锋| 亚洲福利国产精品| 免费成人小视频| 国产精品一区2区| 成人美女视频在线观看| 91麻豆精品秘密| 欧美激情视频一区二区三区在线播放 | 国产九色sp调教91| 丁香婷婷综合色啪| 欧美精品大片| 99精品欧美一区二区三区| 性欧美videos另类喷潮| 欧美视频一区二区三区| 欧美大肚乱孕交hd孕妇| 国产精品伦理一区二区| 一区二区三区在线影院| 日韩和欧美一区二区|