MySQL鎖的用法介紹

這篇文章主要講解了“MySQL鎖的用法介紹”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“MySQL鎖的用法介紹”吧!

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、網(wǎng)頁(yè)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、開(kāi)陽(yáng)網(wǎng)站維護(hù)、網(wǎng)站推廣。

鎖機(jī)制是數(shù)據(jù)庫(kù)有別于文件系統(tǒng)的一個(gè)重要的特點(diǎn),也是用來(lái)管理并發(fā)訪問(wèn)的一個(gè)有效的方式。MySQL 的鎖分為表級(jí)鎖、頁(yè)級(jí)鎖與行級(jí)鎖。表級(jí)鎖是MySQL中粒度最大的一種鎖,它實(shí)現(xiàn)簡(jiǎn)單,資源消耗較少,被大部分MySQL引擎支持。最常使用的 MYISAM與INNODB都支持表級(jí)鎖定。
表級(jí)鎖定分為兩類,讀鎖與寫(xiě)鎖。讀鎖是預(yù)期將對(duì)數(shù)據(jù)表進(jìn)行讀取操作,鎖定期間保證表不能被修改。寫(xiě)鎖是預(yù)期會(huì)對(duì)數(shù)據(jù)表更新操作,鎖定期間保證表不能被其他線程更新或讀取。
讀鎖:
用法:LOCK TABLE table_name [ AS alias_name ] READ
指定數(shù)據(jù)表,LOCK類型為READ即可,AS別名是可選參數(shù),如果指定別名,使用時(shí)也要指定別名才可
申請(qǐng)讀鎖前提:當(dāng)前沒(méi)有線程對(duì)該數(shù)據(jù)表使用寫(xiě)鎖,否則申請(qǐng)會(huì)阻塞。
操作限制:其他線程可以對(duì)鎖定表使用讀鎖;其他線程不可以對(duì)鎖定表使用寫(xiě)鎖
對(duì)于使用讀鎖的MySQL線程,由于讀鎖不允許任何線程對(duì)鎖定表進(jìn)行修改,在釋放鎖資源前,該線程對(duì)表操作只能進(jìn)行讀操作,寫(xiě)操作時(shí)會(huì)提示非法 操作。而對(duì)于其他沒(méi)使用鎖的MySQL線程,對(duì)鎖定表進(jìn)行讀操作可以正常進(jìn)行,但是進(jìn)行寫(xiě)操作時(shí),線程會(huì)等待讀鎖的釋放,當(dāng)鎖定表的所有讀鎖都釋放時(shí),線 程才會(huì)響應(yīng)寫(xiě)操作。
寫(xiě)鎖:
用法:LOCK TABLE table_name [AS alias_name] [ LOW_PRIORITY ] WRITE
別名用法與讀鎖一樣,寫(xiě)鎖增加了指定優(yōu)先級(jí)的功能,加入LOW_PRIORITY可以指定寫(xiě)鎖為低優(yōu)先級(jí)。
申請(qǐng)寫(xiě)鎖前提:當(dāng)沒(méi)有線程對(duì)該數(shù)據(jù)表使用寫(xiě)鎖與讀鎖,否則申請(qǐng)回阻塞。
操作限制:其他MySQL線程不可以對(duì)鎖表使用寫(xiě)鎖、讀鎖
對(duì)于使用寫(xiě)鎖的MySQL線程,其可以對(duì)鎖定表進(jìn)行讀寫(xiě)操作。但是對(duì)于其他線程,對(duì)指定表讀寫(xiě)操作都是非法的,需要等待直到寫(xiě)鎖釋放。
鎖分配優(yōu)先級(jí):
對(duì)于鎖分配的優(yōu)先級(jí),是: LOW_PRIORITY WRITE < READ < WRITE
1、當(dāng)多個(gè)線程申請(qǐng)鎖,會(huì)優(yōu)先分配給WRITE鎖,不存在WRITE鎖時(shí),才分配READ鎖,LOW_PRIORITY WRITE需要等到WRITE鎖與READ都釋放后,才有機(jī)會(huì)分配到資源。
2、對(duì)于相同優(yōu)先級(jí)的鎖申請(qǐng),分配原則為誰(shuí)先申請(qǐng),誰(shuí)先分配。
注意事項(xiàng):
1、不能操作(查詢或更新)沒(méi)有被鎖定的表。
例如當(dāng)只申請(qǐng)table1的讀鎖,SQL語(yǔ)句中包含對(duì)table2的操作是非法的。例如:
mysql> LOCK TABLE test READ;
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM test_myisam;
ERROR 1100 (HY000): Table 'test_myisam' was not locked with LOCK TABLES
2、不能在一個(gè)SQL中使用兩次表(除非使用別名)
當(dāng)SQL語(yǔ)句中多次使用一張表時(shí),系統(tǒng)會(huì)報(bào)錯(cuò)。例如:
mysql> LOCK TABLE test READ;
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM test WHERE id IN (SELECT id FROM test );
ERROR 1100 (HY000): Table 'test' was not locked with LOCK TABLES
解決這個(gè)問(wèn)題的方法是使用別名,如果多次使用到一個(gè)表,需要聲明多個(gè)別名。
mysql> LOCK TABLE test AS t1 READ, test AS t2 READ;
Query OK, 0 rows affected (0.00 sec)
mysql>  SELECT * FROM test AS t1 WHERE id IN (SELECT id FROM test AS t2);
+----+-----------+
| id | content   |
+----+-----------+
|  1 | tt_1      |
|  3 | new_3     |
|  4 | new_4     |
|  5 | content_5 |
+----+-----------+
4 rows in set (0.00 sec)
3、申請(qǐng)鎖時(shí)使用別名,使用鎖定表時(shí)必須加上別名。

感謝各位的閱讀,以上就是“MySQL鎖的用法介紹”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)MySQL鎖的用法介紹這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

網(wǎng)頁(yè)題目:MySQL鎖的用法介紹
URL分享:http://muchs.cn/article44/picehe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、云服務(wù)器、域名注冊(cè)、品牌網(wǎng)站制作、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)