共計 1849 個字符,預計需要花費 5 分鐘才能閱讀完成。
本篇文章給大家分享的是有關如何鎖定 MySQL 數據庫表,丸趣 TV 小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著丸趣 TV 小編一起來看看吧。
如何鎖定 MySQL 數據庫表
鎖定表的方法
防止客戶機的請求互相干擾或者服務器與維護程序相互干擾的方法主要有多種。如果你關閉數據庫,就可以保證服務器和 myisamchk 和 isamchk 之間沒有交互作用。但是停止服務器的運行并不是一個好注意,因為這樣做會使得沒有故障的數據庫和表也不可用。本節主要討論的過程,是避免服務器和 myisamchk 或 isamchk 之間的交互作用。實現這種功能的方法是對表進行鎖定。
服務器由兩種表的鎖定方法:
1. 內部鎖定
內部鎖定可以避免客戶機的請求相互干擾——例如,避免客戶機的 SELECT 查詢被另一個客戶機的 UPDATE 查詢所干擾。也可以利用內部鎖定機制防止服務器在利用 myisamchk 或 isamchk 檢查或修復表時對表的訪問。
語法:
鎖定表:LOCKTABLEStbl_name{READ|WRITE},[tbl_name{READ|WRITE},…]
解鎖表:UNLOCKTABLES
LOCKTABLES 為當前線程鎖定表。UNLOCKTABLES 釋放被當前線程持有的任何鎖。當線程發出另外一個 LOCKTABLES 時,或當服務器的連接被關閉時,當前線程鎖定的所有表自動被解鎖。
如果一個線程獲得在一個表上的一個 READ 鎖,該線程 (和所有其他線程) 只能從表中讀。如果一個線程獲得一個表上的一個 WRITE 鎖,那么只有持鎖的線程 READ 或 WRITE 表,其他線程被阻止。
每個線程等待 (沒有超時) 直到它獲得它請求的所有鎖。
WRITE 鎖通常比 READ 鎖有更高的優先級,以確保更改盡快被處理。這意味著,如果一個線程獲得 READ 鎖,并且然后另外一個線程請求一個 WRITE 鎖, 隨后的 READ 鎖請求將等待直到 WRITE 線程得到了鎖并且釋放了它。
顯然對于檢查,你只需要獲得讀鎖。再者鐘情跨下,只能讀取表,但不能修改它,因此他也允許其它客戶機讀取表。對于修復,你必須獲得些所以防止任何客戶機在你對表進行操作時修改它。
2. 外部鎖定
服務器還可以使用外部鎖定 (文件級鎖) 來防止其它程序在服務器使用表時修改文件。通常,在表的檢查操作中服務器將外部鎖定與 myisamchk 或 isamchk 作合使用。但是,外部鎖定在某些系統中是禁用的,因為他不能可靠的進行工作。對運行 myisamchk 或 isamchk 所選擇的過程取決于服務器是否能使用外部鎖定。如果不使用,則必修使用內部鎖定協議。
如果服務器用 –skip-locking 選項運行,則外部鎖定禁用。該選項在某些系統中是缺省的,如 Linux。可以通過運行 mysqladminvariables 命令確定服務器是否能夠使用外部鎖定。檢查 skip_locking 變量的值并按以下方法進行:
如果 skip_locking 為 off,則外部鎖定有效您可以繼續并運行人和一個實用程序來檢查表。服務器和實用程序將合作對表進行訪問。但是,運行任何一個實用程序之前,應該使用 mysqladminflush-tables。為了修復表,應該使用表的修復鎖定協議。
如果 skip_locaking 為 on,則禁用外部鎖定,所以在 myisamchk 或 isamchk 檢查修復表示服務器并不知道,最好關閉服務器。如果堅持是服務器保持開啟狀態,月確保在您使用此表示沒有客戶機來訪問它。必須使用卡黨的鎖定協議告訴服務器是該表不被其他客戶機訪問。
如何檢查 MySQL 表的鎖定協議
本節只介紹如果使用表的內部鎖定。對于檢查表的鎖定協議,此過程只針對表的檢查,不針對表的修復。
1. 調用 mysql 發布下列語句:
$mysql–uroot–pdb_namemysql LOCKTABLEtbl_nameREAD;mysql FLUSHTABLES;
該鎖防止其它客戶機在檢查時寫入該表和修改該表。FLUSH 語句導致服務器關閉表的文件,它將刷新仍在告訴緩存中的任何為寫入的改變。
2. 執行檢查過程
$myisamchktbl_name$isamchktbl_name
3. 釋放表鎖
mysql UNLOCKTABLES;
如果 myisamchk 或 isamchk 指出發現該表的問題,將需要執行表的修復。
以上就是如何鎖定 MySQL 數據庫表,丸趣 TV 小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注丸趣 TV 行業資訊頻道。