精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

扒一扒InnoDB數據在硬盤上是如何存放的

存儲 存儲軟件
在InnoDB中,每張表都有各自的主鍵(Primary Key),如果在創建表的時候顯式的定義主鍵,則InnoDB存儲引擎會按如下方式選擇或創建主鍵。

[[313009]]

本文轉載自微信公眾號「學習Java的小姐姐」,轉載本文請聯系學習Java的小姐姐公眾號。

索引組織表

在InnoDB存儲引擎中,表都是按照主鍵順序組織存放的,這種存儲方式的表被稱為索引組織表。

在InnoDB中,每張表都有各自的主鍵(Primary Key),如果在創建表的時候顯式的定義主鍵,則InnoDB存儲引擎會按如下方式選擇或創建主鍵。

首先判斷表中是否有非空的索引,如果有則第一個定義的非空索引作為主鍵

如果不符合上述條件,InnoDB存儲引擎自動創建一個6個字節大小的指針

這樣的描述太干癟啦,我們來動手操作下。

1.選擇第一個定義的非空索引

首先,我們創建表student,并填充兩條測試數據,語句如下:

  1. create table student( 
  2. int , 
  3. int not null
  4. int not null
  5. UNIQUE key (a), 
  6. UNIQUE key (c), 
  7. UNIQUE key (b) 
  8. ); 
  9. insert into student select 1,2,3; 
  10. insert into student select 4,5,6; 

運行結果如下,我們可以看出_rowid的值等于列c的值,那就說明當前存儲的結構是將c作為主鍵的。另外a是可以為空的,雖然他定義唯一鍵的是第一個,但仍然不會作為主鍵。b雖然是先定義列,但是定義唯一鍵是在c之后,所以也不會被作為唯一鍵。

 

2.自動創建6個字節大小的指針

首先,我們創建表score,并填充兩條測試數據,語句如下:

  1. create table score( 
  2. int , 
  3. int , 
  4. int
  5. UNIQUE key (a), 
  6. UNIQUE key (c), 
  7. UNIQUE key (b) 
  8. ); 
  9. insert into score select 1,2,3; 
  10. insert into score select 4,5,6; 

運行結果如下,直接報錯了,不認為_rowid是他的列名,因為沒有滿足條件的列能成為他的主鍵,所以其就自動創建指針來解決問題啦。

InnoDB的邏輯存儲結構(整體)

表空間

表空間可以看做是InnoDB存儲引擎邏輯結構的最高層,所以的數據都存放在表空間里面。

在默認情況下,InnoDB存儲引擎有一個共享表空間ibdata1,即所有數據都存放在這個表空間里面。當然也可以在my.ini參數文件中啟用innodb_file_per_table,則每張表的數據就可以單獨放在一個表空間中。

注意:即使啟用innodb_file_per_table參數,一些回滾信息,系統事務信息等還是在共享的表空間中,其隨著時間的變化大小還是會不斷增大的。單獨的表空間只會存放一些數據及索引信息。

在InnoDB存儲引擎中,對段的管理都是由引擎自身所完成的,DBA不能也沒必要對其進行控制。

區是由連續頁組成的空間,在任何情況下每個區的大小都是1MB,頁的大小為16kb,所以一個區一共有64個連續的頁。

下面詳細描述。

下面詳細描述。

InnoDB行記錄格式(重點)

InnoDB存儲引擎和大多數數據庫一樣,記錄是以行的形式純純的,這就是意味著頁中保存著表的一行行數據。那么問題就來了,他這一行數據是包括哪些部分,除了具體的數據,還有其他的一些額外信息嗎?

首先,我們先來看一下如果沒有指定行格式,其默認的行格式是什么?

新建表test,擁有的字段a,b ,c 。

  1. create table test( 
  2. varchar(10), 
  3. varchar (10) not null
  4. char(10) 
  5. ); 
  6. insert into test values'001','Andy','compter'); 
  7. insert into test values'002','Bob',NULL); 

如下圖所示,默認的行格式是Compact ,該行格式是在MySQL5.0中引入的,其設計目標是高校的存儲數據。簡單來說,一個頁存放的行數據越多,其性能越高。針對這個描述,咱先放在一邊,之后看到其他的行格式,咱對比著看,為啥compact性能高?

 


 

 

下圖為行格式Compact的大概結構,先瞅一眼,主要分為兩個部分,額外信息和真實數據。額外信息包括變成字段長度,NULL值列表,記錄頭信息,真實數據即為該行記錄有多少列,每列數據有哪些。其中記錄頭信息包括記錄刪除位,記錄類型,下一個指針的位置。

注意,記錄頭信息還有很多為其他信息,但是重要的就這幾個。是不是不知道他們是干撒的,一臉懵逼中,沒事,這還是混個臉熟,下一部分來慢慢盤他。

 

變長字段長度

MySQL支持一些變長的數據類型,如varchar,text,blob,變長長度存儲多少字節的數據是不固定的,所以我們在存儲真實數據的時候,需要將這些數據占用的字節數也要存儲起來。

剛才我們新增了兩條數據,先拿第一個數據為例,將真正數據占用的字節長度都存放在記錄的開頭部位,從而形成一個變長字段長度列表,逆序存放。如下圖,所以最終第一條記錄存放的十六進制為08 04 03,他們之間沒有空格,是為了顯示的效果才加了空格。那第二條記錄很明顯是03 03.

注意:如果表中沒有變長字段,則該字段不存在。

 

NULL值列表

我們知道表中的某些列可能存儲NULL值,如果這些NULL值放在記錄的真實數據中存儲會占用空間,所以Compact將這些值為NULL的列統一管理起來,存儲在NULL表中。

注意:跟變長字段一樣,如果表中沒有NULL值的列,則該字段不存在。注意:MySQL規定NULL值列表必須是整數個字節的位表示,如果使用的二進制位歌手不是整數個字節,則在字節的高位補0.

第一行數據雖然沒有NULL值,但是a,c是可能存儲NULL值的列,所以NULL值列表如下,0表示列所對應的值不為NULL,1表示列所對應的值為NULL。

 

第二行數據a不是NULL,c是NULL,所以對應的NULL值列表如下。

 

記錄頭信息

  • 記錄刪除位(delete_mask):0為未刪除,1為刪除
  • 記錄類型(record_type):0表示普通記錄,1表示B+樹非葉子節點記錄,2表示最小記錄,3表示最大記錄。
  • 下一個指針的位置(next_record):表示從當前記錄的真實數據到下一條記錄的真實數據之間的地址偏移量。比如第一條記錄的next_record為20,那么意味從第一條記錄的真實數據的地址處向后找32個字節便是下一條記錄的真實數據。實際上就是鏈表結構。

InnoDB數據頁結構(重點)

下圖為數據頁的整體結構,咱先來了解下大概,再慢慢盤它。

 

文件頭(File Header)

頁的一些通用信息,包括該頁屬于哪個表空間,InnoDB存儲引擎頁的類型。

頁頭(Page Header)

記錄數據頁的狀態信息。

最小記錄+最大記錄(Infimum+supermum)

在InnoDB存儲引擎中,每個數據頁都有兩條虛擬的行記錄,用來限定記錄的邊界。

Infimum記錄是指比該頁中任何主鍵值都要小的值,Supermum記錄是指比該頁中任何主鍵值都要大的值。

這兩個值在頁創建時都會被的創建,并且在任何情況下不會被刪除。

這兩條記錄的構造十分簡單,都是有5個字節大小的記錄頭信息和8個字節的固定部分組成的。

注意:上面提到了最小記錄的record_type為2,最大記錄的record_type為3。

用戶記錄(User Records)

重點來了,這邊是數據實際存儲位置,上面已經針對行格式做了詳細的劃分,現在咱就長話短說啦。

如果我刪除了第二行記錄,這條記錄并不是立刻刪除了,只是將刪除記錄位改為1啦。并且將他前面一條數據的指針指向他后面一條數據的地址,從而跳過這一條數據。

至于為什么會這樣做呢?是為了節約時間和空間的消耗。如果在刪除的時候,立刻從磁盤上移除,那么其他記錄在磁盤上重新排列需要性能消耗,所以在刪除的時候,只會將所有被刪除的記錄組成一個垃圾鏈表,稍后操作。或者有新紀錄插入的時候,覆蓋掉剛才的存儲空間。

 

空閑空間(Free Space)

不重要。

頁面目錄(Page Directory)

我們現在已經找到記錄在頁面中按照主鍵由小到達順序組成一個單鏈表,那如果想根據主鍵查詢頁中的某條記錄怎么辦?

最蠢的方法肯定是按單鏈表的順序從頭到尾的查找,因為只有知道前面一條記錄的記錄的地址,才能根據指針找到下一條記錄。但是這個有個明顯的缺點,就是太慢了,如果有1000條數據,一個個的查詢,如果最后一條記錄才滿足條件,那就太浪費時間啦。

我們可以先從順序表中想想,如果順序表中要找一個記錄,我們除了從頭開始查之外,還可以采用二分法,可以提升查詢速度。

那么在單鏈表中是否可以采用二分法呢?答案是肯定的。即采用目錄的形式,將所有的記錄劃分為多個記錄塊,然后取每個記錄塊的最大的值,將其組成一個目錄,在查找的時候,先查目錄,能判斷在哪個區間內。這個過程就類似于在書中找到某一個概念,要從目錄先找一樣。

文章尾部(File Tailer)

不重要。哈哈哈。

寫在最后

寫在最后

該篇借鑒的博文,書籍如下。

《MySQL技術內幕——InnoDB存儲引擎》MySQL是如何運行的https://blog.csdn.net/u010922732/article/details/82994253#%E4%B8%80%20%E5%AD%98%E5%82%A8%E5%BC%95%E6%93%8E%E4%BD%9C%E7%94%A8%E4%BA%8E%E4%BB%80%E4%B9%88%E5%AF%B9%E8%B1%A1

https://juejin.im/post/5cb3e3dfe51d456e3428c0db

責任編輯:武曉燕 來源: 學習Java的小姐姐
相關推薦

2015-09-16 14:04:06

大數據巨頭

2025-06-04 01:20:00

2015-09-21 10:07:31

2022-07-11 20:46:39

AQSJava

2019-10-21 10:59:52

編程語言JavaC

2019-09-10 07:29:44

2018-04-03 15:42:40

2023-01-30 22:10:12

BeanSpring容器

2015-09-16 14:11:47

2019-02-25 22:46:39

2015-10-15 13:38:39

2015-08-18 09:12:54

app推廣渠道

2023-04-10 23:05:54

NacosOpenFeignRibbon

2019-01-03 11:09:19

2021-05-13 05:25:16

數據分析數分培訓大數據

2019-04-28 14:24:54

吳亦凡流量數據

2024-12-04 13:54:19

pnpm存儲項目

2015-02-25 20:16:06

2018-07-30 15:49:12

2017-09-07 18:45:51

C#
點贊
收藏

51CTO技術棧公眾號

欧洲亚洲一区二区| 日本国产精品视频| 亚洲视频在线播放免费| 亚洲福利影院| 国产精品久久三| 超碰97网站| 三级网站在线播放| 一级毛片免费高清中文字幕久久网| 精品国产露脸精彩对白| 一本久道中文无码字幕av| 大片免费在线观看| 2014亚洲片线观看视频免费| 国产专区精品视频| 在线能看的av| 这里只有精品在线| 亚洲午夜精品视频| 折磨小男生性器羞耻的故事| jizz欧美| 色中色一区二区| 97在线免费视频观看| 国产小视频在线| 成人黄色av电影| 91久久精品国产91性色| 狠狠狠狠狠狠狠| 1024日韩| 欧美激情亚洲一区| 91高清免费观看| 成人直播大秀| 亚洲网址你懂得| 国产草草浮力影院| 亚洲一区电影| 56国语精品自产拍在线观看| 色婷婷综合久久久久中文字幕| 男女视频在线| 亚洲精品免费视频| 中文字幕黄色大片| 丁香婷婷在线观看| 久久青草欧美一区二区三区| 国产三区二区一区久久| 国产日韩欧美视频在线观看| 日韩国产精品大片| 国产极品jizzhd欧美| 91在线视频在线观看| 在线看片成人| 国内精品久久久久久久久| 欧美极品视频在线观看| 欧美在线亚洲| 欧美成人免费一级人片100| 亚洲毛片亚洲毛片亚洲毛片| 在线成人动漫av| 亚洲欧美999| www.色天使| 蜜桃一区二区三区| 伊人久久大香线蕉av一区二区| 少妇光屁股影院| 国产精品密蕾丝视频下载| 亚洲免费视频观看| 久久久久久久久久久久| 日韩一区三区| 久久久精品日本| 老湿机69福利| 国产精品地址| 91av在线网站| 国产主播第一页| 免费观看久久久4p| 国产自产女人91一区在线观看| 国产欧美一区二区三区视频在线观看| 韩国三级在线一区| 操一操视频一区| 五月婷婷开心中文字幕| 久久久噜噜噜久噜久久综合| 波多野结衣视频一区| 亚洲男女自偷自拍图片另类| 无码 人妻 在线 视频| 久久av网址| 中文字幕久久久| 黄色一级片中国| 亚洲激情社区| 国产成+人+综合+亚洲欧洲| 中文字幕在线一| 国产精品一区二区男女羞羞无遮挡 | 五月婷婷另类国产| 黄在线观看网站| 狂野欧美性猛交xxxx| 日韩一区二区影院| 国产成人无码一区二区在线观看| 国模精品一区| 久久手机免费视频| 国产黄色片免费看| 麻豆精品精品国产自在97香蕉| 亚洲中国色老太| 台湾av在线二三区观看| 国产精品久久久久久亚洲伦 | 影音先锋在线视频| 欧美日韩免费网站| 欧美日韩一区二区三区69堂| 福利在线一区| 在线观看国产精品日韩av| 欧美黑人一级片| 久久综合中文| 成人av资源| 精品乱码一区二区三四区视频| 国产精品国产a级| 国产精品12345| 成人动漫视频在线观看| 亚洲美女动态图120秒| 国产精品精品软件男同| 午夜亚洲一区| 国产精品9999久久久久仙踪林| 国产一级免费在线观看| 亚洲图片欧美视频| 911福利视频| 亚洲尤物av| 国内精品模特av私拍在线观看| 亚洲熟妇av乱码在线观看| 成人av先锋影音| 三级网在线观看| 国产精品极品美女在线观看| 精品久久久三级丝袜| 天堂网中文在线观看| 老牛国产精品一区的观看方式| 国产精品对白一区二区三区| 黄色在线免费网站| 欧美日韩一区二区在线视频| 亚洲专区区免费| 9久re热视频在线精品| 91在线高清视频| 亚洲麻豆精品| 欧美自拍丝袜亚洲| 亚洲国产日韩一区无码精品久久久| 国内一区二区三区| 91欧美激情另类亚洲| www.久久热.com| 色综合久久中文综合久久97| 五十路六十路七十路熟婆 | 国产日韩欧美制服另类| 男人添女人下部高潮视频在观看| 清纯唯美激情亚洲| 美女av一区二区| 一级做a爱片性色毛片| 日本一区二区三区dvd视频在线 | 亚洲精品一区二区毛豆| 欧美成a人片在线观看久| 日韩麻豆第一页| 五月婷婷激情网| 91视频精品在这里| 九九九九免费视频| 日韩美女毛片| 国产91精品久久久久久久| 少妇人妻一区二区| 欧美日韩国产色视频| 亚洲国产精品成人综合久久久| 伊人精品成人久久综合软件| 国产伦精品一区二区三区免| 黄网站在线观| 日韩久久午夜影院| а中文在线天堂| 国产精品激情偷乱一区二区∴| 伊人影院综合在线| 在线中文字幕亚洲| 国产精品久久国产三级国电话系列| 俺来也官网欧美久久精品| 亚洲第一二三四五区| 日韩 欧美 综合| 久久久久久久久蜜桃| 午夜免费福利在线| 忘忧草精品久久久久久久高清| 91沈先生在线观看| 欧美xxxx做受欧美88bbw| 日韩电影中文字幕在线| 精品久久久久久久久久久国产字幕| 国产精品素人视频| 九九九九九九九九| 亚洲精品在线二区| 日本精品视频一区| 国产麻豆精品| 91精品国产成人| 成人在线免费观看| 欧美一区二区三区白人 | 在线精品视频小说1| 三级黄色录像视频| 成人免费视频视频在线观看免费 | 国产精品123| 无码人妻丰满熟妇区96| 日韩精品dvd| 91在线在线观看| 亚洲人体视频| 久久精品中文字幕免费mv| 欧美视频久久久| 欧美性生活久久| 日韩欧美不卡视频| 中文字幕欧美国产| 伦理片一区二区| 日韩av不卡在线观看| www.国产在线视频| 成人情趣视频网站| 精品一区二区国产| 粉嫩一区二区三区在线观看| 91av成人在线| 国产日产一区二区三区| 亚洲精品中文字幕女同| 精品国产九九九| 欧美日韩一区不卡| 久久夜色精品亚洲| 亚洲免费三区一区二区| 色婷婷av777| 国产.欧美.日韩| 免费精品99久久国产综合精品应用| 在线看片成人| 国产欧美123| 日韩精品诱惑一区?区三区| 国产一区二区三区四区五区加勒比| jvid一区二区三区| 88国产精品欧美一区二区三区| 午夜羞羞小视频在线观看| 国产亚洲精品一区二555| 人妻妺妺窝人体色www聚色窝| 欧美日韩亚洲另类| 欧美国产一级片| 天天色 色综合| 精品无码人妻一区二区三| 国产精品短视频| 免费看91的网站| 久久亚洲综合色一区二区三区 | 国产又粗又大又爽视频| 色老汉av一区二区三区| 国产无遮挡又黄又爽在线观看| 亚洲日本电影在线| 婷婷国产成人精品视频| 中文字幕乱码一区二区免费| 成年人在线观看av| 91香蕉视频黄| 在线天堂www在线国语对白| 成人午夜电影网站| 中文字幕制服丝袜| 国产成人免费xxxxxxxx| 韩国三级hd中文字幕有哪些| 国内欧美视频一区二区| 国产成年人视频网站| 另类小说综合欧美亚洲| www.com污| 国产做a爰片久久毛片| 五月天视频在线观看| 久久66热re国产| 在线视频观看91| 国产大片一区二区| 性xxxxxxxxx| 成人黄色国产精品网站大全在线免费观看| 麻豆传媒在线看| 国产东北露脸精品视频| 国产国语老龄妇女a片| 成人免费va视频| 亚州av综合色区无码一区| 久久综合久久综合亚洲| 国产精品久久久久无码av色戒| 久久色在线视频| 久久久精品成人| 国产精品不卡在线观看| 国产女片a归国片aa| 亚洲一区国产视频| 国产精品7777777| 欧美性猛交xxxx乱大交极品| 人人妻人人爽人人澡人人精品| 欧美伊人久久久久久午夜久久久久| 超碰在线97观看| 91麻豆精品国产91久久久 | 91啪亚洲精品| 精品成人无码一区二区三区| 国产精品美女久久久久久久 | av噜噜色噜噜久久| 加勒比色老久久爱综合网| 欧美日韩电影一区二区| 日韩精品一区二区三区免费观看| 无码人妻精品一区二区三区99v| 欧美激情五月| 日本精品免费在线观看| 久久国产精品区| 永久免费未满蜜桃| 国产人伦精品一区二区| 成年人一级黄色片| 欧美小视频在线| 国产永久免费视频| 亚洲国产女人aaa毛片在线| 国产在线视频网站| 欧美精品在线极品| 久久人体大尺度| 亚洲自拍中文字幕| 亚洲成a人片77777在线播放 | av片在线观看免费| 91超碰中文字幕久久精品| 农村妇女一区二区| 动漫美女被爆操久久久| 国产一区二区三区电影在线观看 | 亚洲精品视频网址| 一区二区高清视频在线观看| 国产又粗又猛又黄视频| 欧美成人官网二区| 香蕉视频免费在线播放| 亚州欧美日韩中文视频| 亚洲国产天堂| 久久久久久久久一区二区| 婷婷激情图片久久| 成人在线观看黄| 成人激情av网| 色欲一区二区三区精品a片| 欧美日韩综合视频| www.日本在线观看| 色悠悠久久88| 欧美无毛视频| 国产日韩二区| 欧美一区久久| 久久婷五月综合| 久久综合五月天婷婷伊人| 欧产日产国产v| 欧美色国产精品| 毛片在线免费| 国产综合在线视频| 欧美日本三级| 在线视频亚洲自拍| 日韩高清一区二区| 国产精品一区二区入口九绯色| 亚洲综合视频在线观看| 一区二区三区亚洲视频| 揄拍成人国产精品视频| 中文字幕乱码在线播放| 国产日韩欧美亚洲一区| 午夜性色一区二区三区免费视频| 午夜精品中文字幕| 亚洲国产精品99久久久久久久久 | 欧美一区永久视频免费观看| jizz在线免费观看| 欧美在线视频免费| 欧美人妖在线观看| 国产九九九九九| 不卡一区中文字幕| 日韩精品成人在线| 精品va天堂亚洲国产| 蜜乳av一区| 国产精品视频福利| 亚洲黑丝一区二区| 欧美大喷水吹潮合集在线观看| 亚洲五月六月丁香激情| 人妻va精品va欧美va| 97久久精品视频| 红杏一区二区三区| 欧美 日韩 国产 高清| 99久久伊人网影院| 欧产日产国产69| 亚洲人成电影网站色| 五月激情久久| 亚洲精品中字| 韩国视频一区二区| 久久久久99精品成人片毛片| 精品国产网站在线观看| 99热99re6国产在线播放| 国产一级二级三级精品| 99在线精品视频在线观看| 大地资源二中文在线影视观看 | 992kp免费看片| 夜夜操天天操亚洲| 天堂在线观看av| 欧洲一区二区视频| 清纯唯美日韩| 日本成人在线免费| 精品久久久一区二区| 免费在线一级视频| 国产精品自产拍高潮在线观看| 四季av一区二区凹凸精品| 美女被艹视频网站| 亚洲国产精品一区二区www在线| 天天干在线观看| 国产精品久久久久av| 天天av综合| 人妖粗暴刺激videos呻吟| 色天使色偷偷av一区二区| 1024免费在线视频| 99九九电视剧免费观看| 亚洲一区一卡| 一级黄色片日本| 日韩国产中文字幕| 欧美成人高清视频在线观看| 欧美久久久久久久久久久久久久| 99久久777色| 91在线视频国产| 韩国v欧美v日本v亚洲| 欧美日韩国产传媒| 国内自拍偷拍视频| 欧美亚洲综合网| 成全电影大全在线观看| 日韩性感在线| a亚洲天堂av| 一区二区日韩在线观看| 8x海外华人永久免费日韩内陆视频| 日韩欧美一区免费| 影音先锋人妻啪啪av资源网站| 欧美亚洲国产一卡| 成人福利影视| 国产成人精品免费看在线播放| 91麻豆免费看片| 亚洲精品18在线观看|