上一篇剛剛簡潔化的介紹了B-TREE的幾個結構與儲存方式,但索引和資料的關係感覺上還是沒有關聯起來,
那麼本篇,就透過實際的一個資料行的例子,建立索引後,他們在B+TREE上的排序是什麼順序。
一.模擬建立原始資料
下圖中,左邊是自己方便說明,模擬的資料。引擎為mysiam~
右邊是用EXCEL把它們隨機排列後的一個正常仿真數據表,把主鍵按照1-27再排列(不隨機的話我在模擬數據時本來就是按順序寫的,再加索引看不大出這個索引排序的過程)
也就是說右邊的數據,使我們要測試的原始數據,沒建索引前是這樣排序的,後邊所有的數據都是以這個為依準進行的,這樣更好看索引產生後的排序效果。
該表有4個字段(id,a,b,c),共27行資料
二.建立索引a
如下圖,當建立索引a以後,在該索引結構中,從原來的依照主鍵ID排序,變成了新的規則,我們說索引其實就是一個資料結構。則建立索引a,就是新另建立一個結構,排序依照字段a規則排序,第一條為主鍵ID為1代表的資料行,第二條ID=3的資料行,第三條ID=5代表的數據行。 。 。
新排序主鍵ID(以ID代表他們這行的資料):1 3 5 6 9 16 18 23 26 2 10 11 12 13 16 18 23 26 2 10 11 12 13 14 15 23 25 15 2072 2072 207
不難發現,當字段a相同時,他們的排列前後主鍵ID來排,例如同樣是a=1.1的值,但是他們的排序是ID值為1,3,5,6。 。對應的行,和主鍵ID排序順序相近。 (即相同值時的排序,ID小的在前邊)
三.建立索引(a,b)
如下圖,當建立聯合索引(a,b)以後,在該索引結構中,從原來的依照主鍵ID排序,變成了新的規則,排序規則先依照欄位a排序,在a的基礎上在依照欄位b排序。即在索引a的基礎上,對字段b也進行了排序。
新排序主鍵ID(以ID代表他們這行的資料):6 18 23 10 15 20 7 22 27 1 3 26 2 11 25 4 8 24 5 9 16 12 13 14 17 19 21
不難發現,當字段a,b值都相同時,他們的排列前後,也是由主鍵ID決定的,例如同樣是a=1.1,b=2.1的行(18,6,23),但是他們的排序是6,18,23。
字段(a,b)索引,先按a索引排序,然後在a的基礎上,按照b排序
6 18 23 10 15 20 7 22 27 1 3 26 2 11 25 4 8 24 5 9 16 129 11 13 14 17 19 21
四.建立索引(a,b,c)
欄位(a,b,c)索引,先按a,b索引排序,然後在(a,b)的基礎上,依照c排序
新排序主鍵ID(以ID代表他們這行的資料):23 6 18 15 20 10 27 22 7 1 26 3 11 2 25 24 4 8 5 16 9 12 14 13 17 19 21
。
我們知道,讀取數據的一個過程(相當於找房間的過程),如果有索引(房間登記表),先讀取索引的資料結構(因為它資料小讀取快嘛),在其結構的葉子節點,找到真實物理磁碟的存放位置(相當於找到門牌號碼了),然後拿著門牌號碼去磁碟裡直接拿數據,這就是一個讀取資料的過程。如果沒索引那你就相當於不知道目的地,就挨個房間找吧。
當沒有索引時,其實主鍵ID就是他們的索引,按照主鍵ID從小到大的規則排列;
當有所索引時,索引a,聯合索引(a,b),聯合索引(a,b ,c)三者的對應3個B+TREE結構上,其葉子節點末尾指向的實體磁碟是不一樣的。
結論:
1.如果沒有建立索引,是按照ID主鍵遞增排列
2.當建立了索引a,會產生一個新的結構索引(B+TREE)用來記錄新的一個結構規則,方便快速查找
5.當建立了索引,非索引的列預設是按照ID遞增來排序的
更多結論:Mysql-索引總結:http://blog.csdn.net/ty_hf/article/details/ 53526405
當新insert一條資料時,儲存資料的同時,也會維護此表的一個索引,把它安置到一個合適的位置。解釋了為什麼再資料量特別大的時候索引可能會有負面影響,在被索引的表上INSERT和DELETE會變慢,頻繁的插入刪除資料同樣會對維護索引消耗時間,瓶頸多少? ? 500W?待考證。
以上就是Mysql-索引資料排序的內容,更多相關內容請關注PHP中文網(www.php.cn)!

存儲過程是MySQL中的預編譯SQL語句集合,用於提高性能和簡化複雜操作。 1.提高性能:首次編譯後,後續調用無需重新編譯。 2.提高安全性:通過權限控制限制數據表訪問。 3.簡化複雜操作:將多條SQL語句組合,簡化應用層邏輯。

MySQL查詢緩存的工作原理是通過存儲SELECT查詢的結果,當相同查詢再次執行時,直接返回緩存結果。 1)查詢緩存提高數據庫讀取性能,通過哈希值查找緩存結果。 2)配置簡單,在MySQL配置文件中設置query_cache_type和query_cache_size。 3)使用SQL_NO_CACHE關鍵字可以禁用特定查詢的緩存。 4)在高頻更新環境中,查詢緩存可能導致性能瓶頸,需通過監控和調整參數優化使用。

MySQL被廣泛應用於各種項目中的原因包括:1.高性能與可擴展性,支持多種存儲引擎;2.易於使用和維護,配置簡單且工具豐富;3.豐富的生態系統,吸引大量社區和第三方工具支持;4.跨平台支持,適用於多種操作系統。

MySQL數據庫升級的步驟包括:1.備份數據庫,2.停止當前MySQL服務,3.安裝新版本MySQL,4.啟動新版本MySQL服務,5.恢復數據庫。升級過程需注意兼容性問題,並可使用高級工具如PerconaToolkit進行測試和優化。

MySQL備份策略包括邏輯備份、物理備份、增量備份、基於復制的備份和雲備份。 1.邏輯備份使用mysqldump導出數據庫結構和數據,適合小型數據庫和版本遷移。 2.物理備份通過複製數據文件,速度快且全面,但需數據庫一致性。 3.增量備份利用二進制日誌記錄變化,適用於大型數據庫。 4.基於復制的備份通過從服務器備份,減少對生產系統的影響。 5.雲備份如AmazonRDS提供自動化解決方案,但成本和控制需考慮。選擇策略時應考慮數據庫大小、停機容忍度、恢復時間和恢復點目標。

MySQLclusteringenhancesdatabaserobustnessandscalabilitybydistributingdataacrossmultiplenodes.ItusestheNDBenginefordatareplicationandfaulttolerance,ensuringhighavailability.Setupinvolvesconfiguringmanagement,data,andSQLnodes,withcarefulmonitoringandpe

在MySQL中優化數據庫模式設計可通過以下步驟提升性能:1.索引優化:在常用查詢列上創建索引,平衡查詢和插入更新的開銷。 2.表結構優化:通過規範化或反規範化減少數據冗餘,提高訪問效率。 3.數據類型選擇:使用合適的數據類型,如INT替代VARCHAR,減少存儲空間。 4.分區和分錶:對於大數據量,使用分區和分錶分散數據,提升查詢和維護效率。

tooptimizemysqlperformance,lofterTheSeSteps:1)inasemproperIndexingTospeedUpqueries,2)使用ExplaintplaintoAnalyzeandoptimizequeryPerformance,3)ActiveServerConfigurationStersLikeTlikeTlikeTlikeIkeLikeIkeIkeLikeIkeLikeIkeLikeIkeLikeNodb_buffer_pool_sizizeandmax_connections,4)


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版
中文版,非常好用

SublimeText3 Linux新版
SublimeText3 Linux最新版

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。