婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL 8.0 Online DDL快速加列的相關總結

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

熱門標簽:400電話辦理服務價格最實惠 武漢電銷機器人電話 400電話變更申請 呂梁外呼系統 大豐地圖標注app html地圖標注并導航 催天下外呼系統 南太平洋地圖標注 北京金倫外呼系統

問題描述

前幾天同事問了我一個問題:業務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

它的執行示意圖如下:

我們有一個原表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,這個功能使得上面的過程變成了下面這樣:

 它的過程和上面的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: 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)

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

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: 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開始)。

    當然,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快速加列的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • MySQL8.0 如何快速加列
  • Mysql Online DDL的使用詳解
  • MySQL DDL 引發的同步延遲該如何解決
  • 詳解MySQL8.0原子DDL語法
  • MySQL在線DDL工具 gh-ost的原理解析
  • MySQL ddl語句的使用
  • Mysql DDL常見操作匯總
  • 解析MySQL8.0新特性——事務性數據字典與原子DDL
  • MySQL數據定義語言DDL的基礎語句
  • MySQL8.0 DDL原子性特性及實現原理
  • MySQL在線DDL gh-ost使用總結
  • 解決MySQL 5.7中定位DDL被阻塞的問題
  • MySQL8.0新特性之支持原子DDL語句
  • MySQL曝中間人攻擊Riddle漏洞可致用戶名密碼泄露的處理方法

標簽:自貢 龍巖 西寧 徐州 南充 麗水 迪慶 無錫

巨人網絡通訊聲明:本文標題《MySQL 8.0 Online DDL快速加列的相關總結》,本文關鍵詞  MySQL,8.0,Online,DDL,快速,加列,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL 8.0 Online DDL快速加列的相關總結》相關的同類信息!
  • 本頁收集關于MySQL 8.0 Online DDL快速加列的相關總結的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日本成人中文字幕| 欧美日韩久久久一区| 婷婷久久综合九色综合伊人色| 91福利资源站| 91精品国产91久久综合桃花| 精品视频在线免费| 国产中文字幕精品| 亚洲摸摸操操av| 精品国产伦一区二区三区免费 | 欧美日韩精品免费观看视频| 蜜乳av一区二区| 欧美日韩一区视频| 国产91丝袜在线播放0| 亚洲国产精品久久一线不卡| 欧美激情中文字幕一区二区| 337p亚洲精品色噜噜狠狠| 成人高清在线视频| 紧缚捆绑精品一区二区| 自拍视频在线观看一区二区| 亚洲天堂av老司机| 亚洲欧美福利一区二区| 欧美日韩一区不卡| 99热精品一区二区| 精品粉嫩超白一线天av| 日韩一区二区精品葵司在线| 一本一道久久a久久精品| 紧缚奴在线一区二区三区| 亚洲成人精品影院| 亚洲欧洲一区二区三区| 99国产精品国产精品久久| 蜜臀久久99精品久久久画质超高清| 国产亚洲综合性久久久影院| 亚洲欧美日韩一区二区 | 色婷婷综合久久久久中文一区二区 | 亚洲国产视频网站| 国产精品自在欧美一区| 久久99精品久久久久久动态图| 欧美国产日本视频| 日本一区二区三区电影| 欧美成人一区二区三区在线观看| 日韩视频免费直播| 精品日韩一区二区三区| 日韩欧美黄色影院| 国产精品综合一区二区三区| 九九在线精品视频| 激情综合色播五月| 久久综合给合久久狠狠狠97色69| 99精品一区二区三区| 色诱视频网站一区| 欧美日韩精品二区第二页| 日韩午夜在线影院| 久久久精品免费网站| 在线成人小视频| 日韩欧美www| 久久影音资源网| 久久精品欧美一区二区三区不卡| 欧美经典三级视频一区二区三区| 中文字幕免费在线观看视频一区| 欧美日韩在线播放三区四区| 91精品国产91久久久久久一区二区| 中文av一区特黄| 成人免费福利片| 99国产一区二区三精品乱码| 在线中文字幕一区| 91麻豆精品国产自产在线观看一区| 欧美mv和日韩mv的网站| 欧美国产日韩亚洲一区| 欧美一二三四在线| 九九**精品视频免费播放| 日本 国产 欧美色综合| 久久国产精品99久久人人澡| 岛国精品在线观看| 91激情在线视频| 在线观看视频一区二区欧美日韩| 91丨porny丨国产| 欧美三级电影精品| 欧美电影免费提供在线观看| 一区二区三区四区不卡在线| 午夜久久久久久久久久一区二区| 欧美一区二区三区在线视频 | 亚洲午夜久久久久久久久久久| 首页综合国产亚洲丝袜| 日本一区二区三级电影在线观看 | 国产一区二区三区四区五区美女 | av在线不卡免费看| 欧美色综合影院| 久久精品男人的天堂| 亚洲成人久久影院| 丁香网亚洲国际| 91精品国产品国语在线不卡| 亚洲色图第一区| 韩国一区二区在线观看| 久久99精品久久久久久动态图 | 久久人人爽人人爽| 亚洲一二三区在线观看| 国产.精品.日韩.另类.中文.在线.播放| 成人av电影免费观看| 91精品国产综合久久精品性色 | 欧美一区二区免费| 国产精品国产a| 精品在线观看免费| 欧美日韩国产综合草草| 久久五月婷婷丁香社区| 国产一区日韩二区欧美三区| 欧美男人的天堂一二区| 亚洲欧洲国产日本综合| 欧美综合在线视频| 亚洲四区在线观看| 91精品黄色片免费大全| 一区二区不卡在线播放| 91在线观看视频| 久久久久久亚洲综合影院红桃| 日韩av电影免费观看高清完整版在线观看 | 亚洲狠狠丁香婷婷综合久久久| 欧美一区二区三区性视频| 国产精品久久久久精k8| 国产欧美1区2区3区| 国产精品美女久久福利网站| 国产在线不卡一区| 国产日产精品一区| 免费观看在线综合| 午夜精品爽啪视频| 91在线视频在线| 91视视频在线观看入口直接观看www | 五月天久久比比资源色| 精品国产麻豆免费人成网站| 激情文学综合插| 国产精品久久久久一区二区三区共| 日韩视频一区二区在线观看| 蜜臀久久久久久久| 中文字幕一区二区三区在线不卡| 成人网页在线观看| 欧美国产禁国产网站cc| 日韩视频一区在线观看| 国产精品综合久久| 美女精品自拍一二三四| 日韩一区二区三区av| 亚洲精品国久久99热| 亚洲大片免费看| 欧美老女人在线| 一区二区三区免费| 国产精品久久久久久久久晋中 | 18涩涩午夜精品.www| 国产精品污污网站在线观看| 色综合久久中文字幕综合网| 成人亚洲一区二区一| 亚洲综合区在线| 亚洲人吸女人奶水| 欧美情侣在线播放| 欧美一级黄色大片| 欧美日韩久久久一区| 国内一区二区在线| av一区二区不卡| 亚洲一级电影视频| 国产精品另类一区| 久久99精品久久久久久久久久久久 | 久久久另类综合| 久久久亚洲精品石原莉奈| 91极品视觉盛宴| 国产在线乱码一区二区三区| 中文字幕制服丝袜成人av| 奇米影视一区二区三区| 91在线无精精品入口| 麻豆freexxxx性91精品| 亚洲欧洲中文日韩久久av乱码| 日韩欧美中文一区二区| 亚洲视频小说图片| kk眼镜猥琐国模调教系列一区二区 | 久久se精品一区精品二区| 国产精品亚洲视频| 一区精品在线播放| 欧美高清在线视频| 欧美一区二区视频在线观看 | 欧美一区三区四区| 午夜欧美在线一二页| 成人激情免费视频| 免费看黄色91| 777午夜精品免费视频| 亚洲综合色自拍一区| 国产精品国产三级国产三级人妇| 日韩三级在线免费观看| 91成人免费在线视频| 国产成人在线观看免费网站| av中文一区二区三区| 久久精品亚洲麻豆av一区二区 | 日韩福利电影在线| 91在线小视频| 日韩美女主播在线视频一区二区三区 | 亚洲国产一区二区a毛片| 久久精品国产精品亚洲综合| 亚洲成人免费影院| 一区二区高清视频在线观看| 一区二区三区精密机械公司| 日韩精品五月天| 成人教育av在线| 7777精品伊人久久久大香线蕉的 | 日韩精品电影在线| av在线这里只有精品| 欧美mv和日韩mv的网站| 亚洲一区在线播放|