索引可以讓服務器快速定位到表的指定位置.但是這并不是索引的唯一作用,到目前為止可以看到,根據創建索引的數據結構不同,索引也有一些其他的附加作用
最常見的B-Tree索引,按照順序存儲數據,所以mysql可以用來做order by和group by操作,因為數據是有序的,所以B-Tree也就將相關的列值都存儲在一起.最后因為索引中存儲了實際的列值,所以某些查詢只使用索引就能夠完成全部查詢.據此特性,總結下來索引有如下三個優點
1. 索引大大減少了服務器需要掃描的數據量
2. 索引可以幫助服務器避免排序和臨時表
3. 索引可以將隨機I/O變為順序I/O
"索引"這個主題建議閱讀

這書詳細介紹了如何計算索引的成本和作用,如何評估查詢速度,如何分析索引維護的代價和其帶來的好處等
書中介紹了如何評價一個索引是否適合某個查詢的"三星系統",
**索引將相關的記錄放到一起則獲得一星.
如果索引中的數據順序和查找中的順序一致則獲得二星.
如果索引中的列包含了查詢中的需要的全部列則獲得"三星"**
----
索引是最好的解決方案嗎?
索引并不總是最好的工具.總的來說,只有當索引幫助存儲引擎快速查找到記錄帶來的好處大于其帶來的額外工作時,索引才是有效的,對于非常小的表,大部分情況下簡單的全表掃描更高效.
對于中大型的表,索引就非常有效,
但對于特大型的表,建立和使用索引的代價將隨之增長.這種情況下,則需要一種技術可以直接區分查詢需要的一組數據,而不是一條記錄一條記錄的匹配,例如可以使用分區技術
如果表的數量特別多,可以建立一個元數據信息表,用來查詢需要用到的某些特性,例如執行哪些需要聚合多個應用分布在多個表的數據的查詢,則需要記錄"那個用戶的信息存儲在那個表中"的元數據,這樣在查詢時就可以直接忽略那些不包含指定用戶信息的表
對于大型系統,這是一個常用的技巧,事實上,Infobright就是使用類似的實現.對于TB級的數據,定位單條記錄的意義不大,所以經常會使用塊級別元數據技術來替代索引
- 書列表
- 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與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯