B-Tree索引可能會碎片化,這會降低查詢效率.碎片化的索引可能會以很差或者無序的方式存儲在磁盤上
根據設計B-Tree需要隨機磁盤訪問才能定位到葉子頁,所以隨機訪問是不可避免的.然而,如果葉子頁在物理分布上是順序且緊密的,那么查詢性能就會更好.否則,對于范圍查詢,索引覆蓋掃描等操作來說,速度可能會降低很多倍,對于索引覆蓋掃描這一點更加明顯
表的數據存儲也可能碎片化.然而,數據存儲的碎片化比索引更加復雜.有三種類型的數據碎片
* 行碎片
這種碎片指的是數據被存儲為多個地方的多個片段中.即使查詢只從索引中訪問一行記錄,行碎片也會導致性能下降
* 行間碎片
行間碎片是值邏輯上順序的頁,或者行在磁盤上不是順序存儲的.行間碎片對諸如全表掃描和聚簇索引掃描之類的操作有很大的影響,因為這些操作原本能夠從磁盤上順序存儲的數據中獲益
* 剩余空間碎片
剩余空間碎片是指數據頁中有大量的空余空間,這會導致服務器讀取大量大需要的數據,從而造成浪費
對于myisam表,這三類碎片化都可能發生.但Innodb不會出現短小的行碎片,innodb會移動短小的行并重寫到一個片段中
可以通過執行OPTIMIZE TABLE或者導出再導入的方式來重新整理數據,這對多數存儲引擎都是有效的.對于一些存儲引擎如myisam,可以通過排序算法重建索引的方式來消除水平.老版本的Innodb沒有什么消除碎片化的方法.不過最新版本Innodb新增了"在線"添加和刪除索引的功能,可以通過先刪除,然后再重新創建索引的方式來消除索引的碎片化
對于那些不支持OPTIMIZE TABLE的存儲引擎,可以通過一個不做任何操作的ALTER TABLE操作來重建表.只需要將表的存儲引擎改為當前的引擎即可:
~~~
mysql> ALTER TABLE <table> ENGINE=<engine>;
~~~
對于開啟了`expand_fast_index_creation` 參數的Percona Server,按這種方式重建表,則會同時消除表和索引的碎片化.但對于標準版本的mysql則只會消除表(實際上是聚簇索引)的碎片化.可用先刪除所有索引,然后重建表,最后重新創建索引的方式模擬Percona Server的這個功能
- 書列表
- laravel框架關鍵技術
- 第一章 組件化開發與composer使用
- 簡介
- composer
- 添加路由組件
- 添加控制器模塊
- 添加模型組件
- 添加視圖組件
- 第三章 laravel框架中常用的php語法
- 匿名函數
- 文件包含
- 魔術方法
- 魔術常量
- 反射
- 后期靜態綁定
- traits
- 第四章 laravel框架中使用的HTTP協議基礎
- HTTP協議
- 數據庫
- 數據遷移
- 第六章 laravel框架中的設計模式
- IOC模式
- php核心技術與最佳實踐
- 第一章面向對象核心
- 反射
- 簡單ORM
- 異常和錯誤
- 接口
- 第二章,面向對象設計
- 設計原則
- 單一職責
- 接口隔離
- 開放封閉
- 替換原則
- 依賴倒置
- linux是怎么寫的呢?
- 第三章 正則表達
- 認識正則
- 第四章 php網絡技術應用
- HTTP協議詳解
- php和http相關函數
- 垃圾信息防御措施
- 現代操作系統
- 引論
- sql必知必會
- 限制結果
- 按位置排序
- where求職順序
- IN操作符
- like
- 函數
- group by
- 組合查詢
- 插入檢索出的數據
- 視圖
- 高性能mysql
- 第一章節 mysql架構與歷史
- mysql架構邏輯圖
- 連接與管理
- 優化與運行
- 讀寫鎖
- 鎖粒度
- 表鎖(table lock)
- 行級鎖(row lock)
- ACID
- 隔離級別
- 死鎖
- 隱式和顯式鎖定
- 多版本并發控制
- Innodb概覽
- 第四章節 Schema與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯