索引可以讓查詢鎖定更少的行.如果你的查詢從不訪問哪些不需要的行,那么就會鎖定更少的行,從兩方面來看這對性能都有好處.
Innodb只有在訪問行的時候才會對其加鎖,而索引能夠減少Innodb訪問的行數,從而減少鎖的數量.但這只有當Innodb在存儲引擎層能夠過濾掉索引不需要的行的時候才有效果,
如果索引無法過濾無效的行,那么在Innodb檢索到數據并返回給服務層以后,mysql服務器才能應用到where子句.這時候已經無法避免鎖定行了,innodb已經鎖定這些行了,到適當的時候才會釋放,
在mysql5.1以及更新版本的時候,innodb可以在服務器端過濾掉后就釋放鎖,但是在早期的mysql版本中,Innodb只有在事務提交后才能釋放鎖
看下面的例子
~~~
set autocommit = 0 ;
begin;
select actor_id from sakila.actor where actor_id < 5 and actor_id <> 1 for update;
~~~

底層的存儲引擎的操作是"從索引頭開始獲取滿足條件actor_id < 5"的記錄,服務器并沒有告訴Innodb可以過濾第一行的where條件,注意到explain的extra出現了Using where,這表示mysql服務器將存儲引擎返回行以后再應用where過濾條件
下面的第二個查詢就能證明第一行確實被鎖定,盡管第一個查詢的結果中并沒有這個第一行,保持第一個連接打開,然后開啟第二個連接并執行如下的查詢

這個查詢將會掛起,直到第一個事務釋放第1行的鎖,這個行為對于基于語句的復制的正常運行來說是必要的.(盡管在理論上使用基于行的日志模式,在某些是事務隔離級別下,服務器不再需要鎖定行,但是實際上經常發現無法實現這種預期的行為.知道mysql5.6.3版本,在read-commit隔離級別和基于行的日志模式下,這個例子還是會導致鎖)
就像這個例子顯示的,即使使用了索引,Innodb也可能鎖住一些不需要的數據.如果不能使用索引查找和鎖定行的話問題可能會很糟糕,mysql會做全表掃描并鎖住所有的行,而不管是不是需要的
關于Innodb,索引和鎖有一些很少有人知道的細節,Innodb在二級索引上使用共享(讀)鎖,但訪問主鍵索引需要排他(寫)鎖,這消除了使用索引覆蓋的可能性,并且使得select for update 比 lock in share mode或非鎖定查詢要慢很多
- 書列表
- 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與數據類型優化
- 選擇優化的數據類型
- 日期和時間類型
- 標識列
- 特殊類型數據
- 表設計中的缺陷
- 范式
- 計數器表
- 第五章 創建高性能索引
- 索引基礎
- 索引類型
- 索引的優點
- 高性能索引策略
- 選擇合適的索引列順序
- 聚簇索引
- 順序的主鍵什么時候會造成更壞的后果
- 覆蓋索引
- 使用索引掃描來做排序
- 壓縮索引
- 冗余和重復索引
- 索引和鎖
- 支持多種過濾條件
- 什么是范圍條件
- 優化排序
- 維護索引和表
- 表損壞
- 減少索引和數據的碎片
- 第六章 查詢性能優化
- 掃描的行數和訪問類型
- 重構查詢方式
- 查詢執行的基礎
- 重構-改善既有代碼設計
- 第一章-重構
- 什么是重構
- 第一個案列
- 重構第一步
- 王垠博客
- 多態取代價格相關邏輯