新聞中心
MySQL行級鎖使我們經(jīng)常會遇到的問題,下面為您介紹MySQL行級鎖的優(yōu)點和缺點,希望可以讓您對MySQL行級鎖有更多的了解。

創(chuàng)新互聯(lián)公司服務(wù)項目包括汝南網(wǎng)站建設(shè)、汝南網(wǎng)站制作、汝南網(wǎng)頁制作以及汝南網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,汝南網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到汝南省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
如果想要在一個表上做大量的 INSERT 和 SELECT 操作,但是并行的插入?yún)s不可能時,可以將記錄插入到臨時表中,然后定期將臨時表中的數(shù)據(jù)更新到實際的表里。可以用以下命令實現(xiàn):
mysql> LOCK TABLES real_table WRITE, insert_table WRITE;
mysql> INSERT INTO real_table SELECT * FROM insert_table;
mysql> TRUNCATE TABLE insert_table;
mysql> UNLOCK TABLES;
InnoDB 使用行級鎖,BDB 使用頁級鎖。對于 InnoDB 和 BDB 存儲引擎來說,是可能產(chǎn)生死鎖的。這是因為 InnoDB 會自動捕獲行鎖,BDB 會在執(zhí)行 SQL 語句時捕獲頁鎖的,而不是在事務(wù)的開始就這么做。
MySQL行級鎖的優(yōu)點有:
在很多線程請求不同記錄時減少沖突鎖。
事務(wù)回滾時減少改變數(shù)據(jù)。
使長時間對單獨的一行記錄加鎖成為可能。
MySQL行級鎖的缺點有:
比頁級鎖和表級鎖消耗更多的內(nèi)存。
當(dāng)在大量表中使用時,比頁級鎖和表級鎖更慢,因為他需要請求更多的所資源。
當(dāng)需要頻繁對大部分?jǐn)?shù)據(jù)做 GROUP BY 操作或者需要頻繁掃描整個表時,就明顯的比其它鎖更糟糕。
使用更高層的鎖的話,就能更方便的支持各種不同的類型應(yīng)用程序,因為這種鎖的開銷比行級鎖小多了。
表級鎖在下列幾種情況下比頁級鎖和行級鎖更優(yōu)越:
很多操作都是讀表。
在嚴(yán)格條件的索引上讀取和更新,當(dāng)更新或者刪除可以用單獨的索引來讀取得到時:
UPDATE tbl_name SET column=value WHERE unique_key_col=key_value;
DELETE FROM tbl_name WHERE unique_key_col=key_value;
SELECT 和 INSERT 語句并發(fā)的執(zhí)行,但是只有很少的 UPDATE 和 DELETE 語句。
很多的掃描表和對全表的 GROUP BY 操作,但是沒有任何寫表。
表級鎖和行級鎖或頁級鎖之間的不同之處還在于:
將同時有一個寫和多個讀的地方做版本(例如在MySQL中的并發(fā)插入)。也就是說,數(shù)據(jù)庫/表支持根據(jù)開始訪問數(shù)據(jù)時間點的不同支持各種不同的試圖。其它名有:時間行程,寫復(fù)制,或者是按需復(fù)制。
【編輯推薦】
單表多字段MySQL模糊查詢的實現(xiàn)
MySQL字段的長度
帶您深入了解MySQL索引類型
MySQL字段自增長的實現(xiàn)
Mysql外鍵用法分析
分享題目:MySQL行級鎖的優(yōu)點和缺點
本文路徑:http://fisionsoft.com.cn/article/dhegoei.html


咨詢
建站咨詢
