鎖的概念
①、鎖,在現實生活中是為我們想要隱藏於外界所使用的一種工具。
②、在計算機中,是協調多個程序或執行緒併發訪問某一資源的一種機制。
③、在資料庫當中,除了傳統的計算資源(cpu、ram、i/o等等)的爭用之外,資料也是一種供許多使用者共享訪問的資源。
④、如何保證資料併發訪問的一致性、有效性,是所有資料庫必須解決的乙個問題。
⑤、鎖的衝突也是影響資料庫併發訪問效能的乙個重要因素。
mysql鎖的概述
相對於其它資料庫而言,mysql的鎖機制比較簡單,其最 顯著的特點是不同的儲存引擎支援不同的鎖機制。比如,myisam和memory儲存引擎採用的是表級鎖(table-level locking)。bdb儲存引擎採用的是頁面鎖(page-level locking),但也支援表級鎖。innodb儲存引擎既支援行級鎖(row-level locking),也支援表級鎖,但預設情況下是採用行級鎖。
表級鎖:表級鎖是mysql中鎖定粒度最大的一種鎖,表示對當前操作的整張表加鎖。它開銷小,加鎖快;不會出現死鎖;鎖定粒度大,發生鎖衝突的概率最高,併發度最低。
行級鎖:行級鎖是mysql中鎖定粒度最細的一種鎖,表示只針對當前操作的行進行加鎖。開銷大,加鎖慢;會出現死鎖;鎖定粒度最小,發生鎖衝突的概率最低,併發度也最高。
頁級鎖:頁級鎖是mysql中鎖定粒度介於行級鎖和表級鎖中間的一種鎖。表級鎖速度快,但衝突多。行級衝突少,但速度慢。所以取了折衷的頁級,一次鎖定相鄰的一組記錄。bdb支援頁級鎖。開銷和加鎖時間界於表鎖和行鎖之間;會出現死鎖;鎖定粒度界於表鎖和行鎖之間,併發度一般。
舉例說明
①、在購買商品時,商品庫存只有1個的時候,兩個人同時購買的時候,到底是誰買到的問題。
②、會用到事務,先從庫存表中取出物品的資料,然後插入訂單,付款後,插入付款表資訊。
③、更新商品的數量,在這個過程中,使用鎖可以對有限的資源進行保護,解決隔離和併發的矛盾。
鎖的分類
按操作分:
讀鎖(共享鎖):針對同乙份資料,多個讀取操作可以同時進行而不互相影響。
寫鎖(排它鎖):當前寫操作沒有完成前,會阻斷其他寫鎖和讀鎖。
按粒度分:
表鎖行鎖
頁鎖
MySQL 各種鎖的概念
樂觀鎖大多是基於資料版本記錄機制實現,一般是給資料庫表增加乙個 version 字段。讀取資料時,將此版本號一同讀出,之後更新時,對此版本號加一。此時將提交資料的版本資料與資料庫表對應記錄的當前版本資訊進行比對,如果提交的資料版本號大於資料庫表當前版本號,則予以更新,否則認為是過期資料。比如下單操作...
MySQL基本概念 鎖(概念)
mysql效能優化 鎖 首發橙寂部落格 此提示 介紹下對於mysql鎖機制的理解 從基本概念開始 共享鎖的代號是s,是share的縮寫,共享鎖的鎖粒度是行或者元組 多個行 乙個事務獲取了共享鎖之後,可以對鎖定範圍內的資料執行讀操作。排它鎖的代號是x,是exclusive的縮寫,排它鎖的粒度與共享鎖相...
mysql鎖 innodb鎖的基本概念
參考 mysql核心 innodb儲存引擎 第九章 mysql 引擎特性 innodb 事務鎖系統簡介 mysql 引擎特性 innodb 鎖子系統 mysql 引擎分析 innodb行鎖分析 測試環境 mysql 5.6.43版本 基本概念 排他 更新或者刪除 共享 讀取 行級鎖 行鎖 排他x 共...