對於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>LOCKTABLESreal_tableWRITE,insert_tableWRITE;mysql>INSERTINTOreal_tableSELECT*FROMinsert_table;mysql>TRUNCATETABLEinsert_table;mysql>UNLOCKTABLES;InnoDB使用行級鎖,BDB使用頁級鎖。對於InnoDB和BDB儲存引擎來說,是可能產生死鎖的。這是因為InnoDB會自動捕獲行鎖,BDB會在執行SQL語句時捕獲頁鎖的,而不是在事務的開始就這麼做。行級鎖的優點有:在很多執行緒請求不同記錄時減少衝突鎖。事務回滾時減少改變資料。使長時間對單獨的一行記錄加鎖成為可能。
對於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>LOCKTABLESreal_tableWRITE,insert_tableWRITE;mysql>INSERTINTOreal_tableSELECT*FROMinsert_table;mysql>TRUNCATETABLEinsert_table;mysql>UNLOCKTABLES;InnoDB使用行級鎖,BDB使用頁級鎖。對於InnoDB和BDB儲存引擎來說,是可能產生死鎖的。這是因為InnoDB會自動捕獲行鎖,BDB會在執行SQL語句時捕獲頁鎖的,而不是在事務的開始就這麼做。行級鎖的優點有:在很多執行緒請求不同記錄時減少衝突鎖。事務回滾時減少改變資料。使長時間對單獨的一行記錄加鎖成為可能。