封鎖 (資料庫)

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書

封鎖是一項用於多用戶同時訪問資料庫的技術,是實現並行控制的一項重要手段,能夠防止當多用戶覆寫資料庫時造成數據不一致與衝突。當有一個用戶對資料庫內的數據進行操作時,在讀取數據前先鎖住數據,這樣其他用戶就無法訪問和修改該數據,直到這一數據修改並寫回資料庫解除封鎖為止。詹姆斯·尼古拉·格雷最早完整描述了資料庫鎖。

按照粒度可分為:

  • 表鎖(檔案鎖
  • 頁鎖(page-level lock)
  • 記錄鎖(行鎖,因為SQL標準使用「行」的表述)

按照使用方式分為:

  • 互斥鎖(exclusive lock,寫鎖)
  • 共用鎖(sharing lock,讀鎖)

一般說來,獲得鎖並不是禁止其他事務對加鎖的數據的讀/寫,而是阻塞了其他事務對這些數據的加鎖操作。例如,如果一般的select陳述式根本不申請加鎖,所以能直接讀取其他事務已經加了共用鎖的數據。

參考[編輯]