mysql允許在相同列上創建多個索引,無論是有意還是無意的,mysql需要單獨維護重復主鍵索引,并且優化器在優化查詢的時候也需要逐個進行考慮,這會影響性能
重復索引是指在相同列上按照相同的順序創建的相同類型的索引,應該避免這樣創建重復索引,發現以后也應立即刪除
有時候會在不經意之間創建了重復索引,例如下面的代碼
~~~
create table test (
id int not null primary key,
A int not null,
B int not null,
unique(id),
index(id)
)engine=Innodb;
~~~
用戶可能想創建一個主鍵,先加上唯一限制,然后再加上索引以供查詢使用.事實上,mysql的唯一限制和主鍵限制都通過索引實現的.
因此,上面的寫法實際上在相同的列上創建了三個重復的索引.通常并沒有這樣做,除非是在同一列上創建不同類型的索引來滿足不同的查詢需求
如果索引類型不同,并不算是重復索引.例如經常有很好的理由創建key(col)和fulltext key(col)兩種索引
表中的索引越多插入的速度越慢,一般來說,增加新索引將會導致insert update delete操作變慢,特別是當新增索引后導致達到內存瓶頸的時候
解決冗余索引和重復索引很簡單,刪除這些索引就可以,但首先要做的是找出這樣的索引,可以通過寫一些復雜的訪問INFORMATION_SCHEMA表的查詢來找,也可以使用pt-duplicate-key-checker,該工具通過分析表結構來找出冗余和重復的索引
在決定哪些索引可以被刪除的時候要非常小心,innodb的示例中,因為二級索引的葉子節點包含了主鍵值,所以在列A上的索引相當于 (A,ID)上的索引.如果有像 where A = 5 order by ID這樣的查詢,這個索引會很有作用,如果把索引擴展為(A,B),則實際上會變為(A,B,ID),那么上面查詢的order by 子句就無法使用索引排序,只能用文件排序了,所以建議用Percona工具中的pt-upgrade工具來仔細檢查計劃中的索引變更
- 書列表
- 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與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯