MySQL是目前最廣泛使用的數(shù)據(jù)庫之一,其提供了基于隔離級(jí)別實(shí)施的行級(jí)鎖定,并按需使用各類型的鎖定。在MySQL中,行級(jí)鎖定可以幫助并發(fā)場景下的性能提升,但同時(shí)也會(huì)給系統(tǒng)性能帶來負(fù)擔(dān)。在當(dāng)前越來越高的競爭強(qiáng)度下,如何合理使用鎖定,掌握鎖的粒度和類型,是學(xué)習(xí)MySQL的關(guān)鍵所在。
MySQL中的鎖定類型包括行鎖與表鎖,其中行鎖定的實(shí)現(xiàn)方式又分為共享鎖S鎖和排他鎖X鎖。S鎖代表著讀鎖,可以讓多個(gè)事務(wù)同時(shí)訪問被鎖定的行,而X鎖則代表著寫鎖,只能讓一個(gè)事務(wù)進(jìn)行修改操作。什么時(shí)候會(huì)出現(xiàn)S鎖呢?
SELECT * FROM table WHERE column = 'value' LOCK IN SHARE MODE;
在上述查詢語句中,添加了LOCK IN SHARE MODE關(guān)鍵字時(shí),將會(huì)以S鎖的方式鎖定查詢的行。這個(gè)SELECT語句會(huì)在讀取相應(yīng)的數(shù)據(jù)行時(shí)加上S鎖,并會(huì)在事務(wù)結(jié)束之前一直保持。這時(shí)其他事務(wù)仍然可以讀取被鎖行的數(shù)據(jù),但是其他事務(wù)不能對(duì)該行修改,也不能把行上的共享鎖升級(jí)為排他鎖。
除此之外,在某些情況下,MySQL也會(huì)自動(dòng)地給行加上S鎖。具體而言,如果當(dāng)前事務(wù)提交之前沒有加任何額外的鎖,并且該事務(wù)沒有任何修改操作,那么在讀取數(shù)據(jù)時(shí),就會(huì)自動(dòng)地對(duì)行上加上S鎖。