mysql鎖表和解鎖語句分享

2022-04-01 20:19:04 字數 2284 閱讀 5423

**自: 網路.

對於mysql來說,有三種鎖的級別:頁級、表級、行級

頁級的典型代表引擎為bdb。 

表級的典型代表引擎為myisam,memory以及很久以前的isam。 

行級的典型代表引擎為innodb。 

-我們實際應用中用的最多的就是行鎖。 

行級鎖的優點如下: 

1)、當很多連線分別進行不同的查詢時減小lock狀態。 

2)、如果出現異常,可以減少資料的丟失。因為一次可以只回滾一行或者幾行少量的資料。 

行級鎖的缺點如下: 

1)、比頁級鎖和表級鎖要占用更多的記憶體。 

2)、進行查詢時比頁級鎖和表級鎖需要的i/o要多,所以我們經常把行級鎖用在寫操作而不是讀操作。

3)、容易出現死鎖。 

對於寫鎖定如下: 

1)、如果表沒有加鎖,那麼對其加寫鎖定。 

2)、否則,那麼把請求放入寫鎖佇列中。 

對於讀鎖定如下: 

1)、如果表沒有加寫鎖,那麼加乙個讀鎖。 

2)、否則,那麼把請求放到讀鎖佇列中。 

當然我們可以分別用low_priority 以及high_priority在寫和讀操作上來改變這些行為。 

如果想要在乙個表上做大量的 insert 和 select 操作,但是並行的插入卻不可能時,可以將記錄插入到臨時表中,然後定期將臨時表中的資料更新到實際的表裡。可以用以下命令實現: 

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 儲存引擎來說,是可能產生死鎖的。這是因為 innodb 會自動捕獲行鎖,bdb 會在執行 sql 語句時捕獲頁鎖的,而不是在事務的開始就這麼做。 

行級鎖的優點有: 

在很多執行緒請求不同記錄時減少衝突鎖。 

事務回滾時減少改變資料。 

使長時間對單獨的一行記錄加鎖成為可能。 

行級鎖的缺點有: 

比頁級鎖和表級鎖消耗更多的記憶體。 

當在大量表中使用時,比頁級鎖和表級鎖更慢,因為他需要請求更多的所資源。 

當需要頻繁對大部分資料做 group by 操作或者需要頻繁掃瞄整個表時,就明顯的比其它鎖更糟糕。 

使用更高層的鎖的話,就能更方便的支援各種不同的型別應用程式,因為這種鎖的開銷比行級鎖小多了。 

表級鎖在下列幾種情況下比頁級鎖和行級鎖更優越: 

很多操作都是讀表。 

在嚴格條件的索引上讀取和更新,當更新或者刪除可以用單獨的索引來讀取得到時: 

update tbl_name set column=value where unique_key_col=key_value; 

delete from tbl_name where unique_key_col=key_value; 

select 和 insert 語句併發的執行,但是只有很少的 update 和 delete 語句。 

很多的掃瞄表和對全表的 group by 操作,但是沒有任何寫表。 

表級鎖和行級鎖或頁級鎖之間的不同之處還在於: 

將同時有乙個寫和多個讀的地方做版本(例如在mysql中的併發插入)。也就是說,資料庫/表支援根據開始訪問資料時間點的不同支援各種不同的試圖。其它名有:時間行程,寫複製,或者是按需複製。

<?php

//執行sql語句 鎖掉stat_num表

$sql = "lock tables stat_num write"; //

表的write鎖定,阻塞其他所有mysql查詢程序

$databasehandler->execute($sql

); //

執行更新或寫入操作

$sql = "update stat_num set `correct_num`=`correct_num`+1 where stat_date=''";

$databasehandler->execute($sql

); //

當前請求的所有寫操作做完後,執行解鎖sql語句

$sql = "unlock tables";

$databasehandler->execute($sql

); ?>

附: mysql鎖表機制分析: 

mysql鎖表機制詳解: 

mysql鎖表和解鎖語句分享

對於mysql來說,有三種鎖的級別 頁級 表級 行級 頁級的典型代表引擎為bdb。表級的典型代表引擎為myisam,memory以及很久以前的isam。行級的典型代表引擎為innodb。我們實際應用中用的最多的就是行鎖。行級鎖的優點如下 1 當很多連線分別進行不同的查詢時減小lock狀態。2 如果出...

MYSQL鎖表和解鎖語句

對於mysql來說,有三種鎖的級別 頁級 表級 行級 頁級的典型代表引擎為bdb。表級的典型代表引擎為myisam,memory以及很久以前的isam。行級的典型代表引擎為innodb。我們實際應用中用的最多的就是行鎖。行級鎖的優點如下 1 當很多連線分別進行不同的查詢時減小lock狀態。2 如果出...

mysql 解鎖語句 mysql鎖表和解鎖語句

對於mysql來說,有三種鎖的級別 頁級 表級 行級 頁級的典型代表引擎為bdb。表級的典型代表引擎為myisam,memory以及很久以前的isam。行級的典型代表引擎為innodb。我們實際應用中用的最多的就是行鎖。行級鎖的優點如下 1 當很多連線分別進行不同的查詢時減小lock狀態。2 如果出...