MySQL是一個廣泛應用的關系型數據庫管理系統,然而在使用MySQL過程中,有時候我們會發現一改表就會鎖表的情況,那么這是怎么回事呢?
鎖表的情況分兩種: 1.表級鎖:鎖定整張表,一次只能由一個進程進行寫操作; 2.行級鎖:鎖定單行記錄,允許多個進程同時修改不同行的記錄。
MySQL默認使用表級鎖,執行Alter Table等DDL語句時會發生表級鎖。當修改表結構時,MySQL會申請一個MDL(Metadata Lock),該鎖會阻止對應的DDL語句被其它線程執行,從而導致整張表被鎖定。
一改表就鎖表的原因是當我們作出一個DDL改變表的結構時,我們的操作無法在短時間內進行,因此MySQL會持續占有該表的寫鎖定,直到該操作完成。也就是說,在該操作完成前,所有對該表進行寫操作的線程都需要等待。
因此,在修改MySQL表結構之前,我們要慎重考慮是否需要表鎖定,如果有并發操作,且鎖定時間較長,那么我們可能需要替換為行鎖定。
對于InnoDB引擎,可使用如下命令進行修改: ALTER TABLEENGINE=InnoDB ROW_FORMAT=DYNAMIC;
以上就是一改表就鎖表的情況原因及解決方法。正確理解MySQL鎖定機制,能夠幫助我們編寫高效的MySQL程序。
上一篇前進加速 好看的css
下一篇前端面試h5css3