mysql - 數(shù)據(jù)庫為什么需要鎖機制?
問題描述
數(shù)據(jù)庫為什么需要鎖機制?能用代碼舉詳細的例子嗎,謝謝!
問題解答
回答1:比方說搶購場景 10000個人搶一件商品 如果沒有鎖機制 就有可能出現(xiàn)2333個人搶到這件商品 這時候你要賣給誰呢
回答2:數(shù)據(jù)庫和操作系統(tǒng)一樣,是一個多用戶使用的共享資源。當多個用戶并發(fā)地存取數(shù)據(jù) 時,在數(shù)據(jù)庫中就會產(chǎn)生多個事務(wù)同時存取同一數(shù)據(jù)的情況。若對并發(fā)操作不加控制就可能會讀取和存儲不正確的數(shù)據(jù),破壞數(shù)據(jù)庫的一致性。加鎖是實現(xiàn)數(shù)據(jù)庫并 發(fā)控制的一個非常重要的技術(shù)。在實際應用中經(jīng)常會遇到的與鎖相關(guān)的異常情況,當兩個事務(wù)需要一組有沖突的鎖,而不能將事務(wù)繼續(xù)下去的話,就會出現(xiàn)死鎖,嚴 重影響應用的正常執(zhí)行。
在數(shù)據(jù)庫中有兩種基本的鎖類型:排它鎖(Exclusive Locks,即X鎖)和共享鎖(Share Locks,即S鎖)。當數(shù)據(jù)對象被加上排它鎖時,其他的事務(wù)不能對它讀取和修改。加了共享鎖的數(shù)據(jù)對象可以被其他事務(wù)讀取,但不能修改。數(shù)據(jù)庫利用這兩 種基本的鎖類型來對數(shù)據(jù)庫的事務(wù)進行并發(fā)控制。
回答3:主要是用來解決并發(fā)問題的,保證數(shù)據(jù)一致性。教程網(wǎng)上很多的,附個地址給你:http://www.cnblogs.com/fanp/p...
相關(guān)文章:
1. 關(guān)docker hub上有些鏡像的tag被標記““This image has vulnerabilities””2. docker鏡像push報錯3. Docker for Mac 創(chuàng)建的dnsmasq容器連不上/不工作的問題4. javascript - 在 model里定義的 引用表模型時,model為undefined。5. 利用IPMI遠程安裝centos報錯!6. node.js - mongodb查找子對象的名稱為某個值的對象的方法7. 運行python程序時出現(xiàn)“應用程序發(fā)生異常”的內(nèi)存錯誤?8. html5和Flash對抗是什么情況?9. phpstudy8.1沒集成mysql-front10. 前端 - @media query 使用出現(xiàn)的問題?

網(wǎng)公網(wǎng)安備