自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

MySQL數(shù)據(jù)庫表里如何進行鎖定?

數(shù)據(jù)庫 MySQL
此文章主要講述的內(nèi)容是MySQL數(shù)據(jù)庫表里進行鎖定,即,內(nèi)部鎖定與外部鎖定,以下就是文章的 具體內(nèi)容描述,望你會有所收獲。

以下的文章主要介紹的是在MySQL數(shù)據(jù)庫表里進行鎖定的詳細內(nèi)容解析,其中包括內(nèi)部鎖定與外部鎖定,如果你對其相關(guān)的實際操作內(nèi)容感興趣的話,你就可以瀏覽以下的文章了,希望在你今后的學習中會有所幫助。

內(nèi)部鎖定可以避免客戶機的請求相互干擾——例如,避免客戶機的SELECT查詢被另一個客戶機的UPDATE查詢所干擾。也可以利用內(nèi)部鎖定機制防止服務器在利用myisamchk或isamchk檢查或修復表時對表的訪問。
MySQL數(shù)據(jù)庫表進行鎖定,服務器由兩種表的鎖定方法:

1.內(nèi)部鎖定

內(nèi)部鎖定可以避免客戶機的請求相互干擾——例如,避免客戶機的SELECT查詢被另一個客戶機的UPDATE查詢所干擾。也可以利用內(nèi)部鎖定機制防止服務器在利用myisamchk或isamchk檢查或修復表時對表的訪問。

語法:

鎖定表:LOCK TABLES tbl_name {READ | WRITE},[ tbl_name {READ | WRITE},…]

解鎖表:UNLOCK TABLES

LOCK TABLES為當前線程鎖定表。UNLOCK TABLES釋放被當前線程持有的任何鎖。當線程發(fā)出另外一個LOCK TABLES時,或當服務器的連接被關(guān)閉時,當前線程鎖定的所有表自動被解鎖。

如果一個線程獲得在一個表上的一個READ鎖,該線程(和所有其他線程)只能從表中讀。如果一個線程獲得一個表上的一個WRITE鎖,那么只有持鎖的線程READ或WRITE表,其他線程被阻止。

每個線程等待(沒有超時)直到它獲得它請求的所有鎖。

WRITE鎖通常比READ鎖有更高的優(yōu)先級,以確保更改盡快被處理。這意味著,如果一個線程獲得READ鎖,并且然后另外一個線程請求一個WRITE鎖, 隨后的READ鎖請求將等待直到WRITE線程得到了鎖并且釋放了它。

顯然對于檢查,你只需要獲得讀鎖。再者鐘情跨下,只能讀取表,但不能修改它,因此他也允許其它客戶機讀取表。對于修復,你必須獲得些所以防止任何客戶機在你對表進行操作時修改它。

2.外部鎖定

服務器還可以使用外部鎖定(文件級鎖)來防止其它程序在服務器使用表時修改文件。通常,在表的檢查操作中服務器將外部鎖定與myisamchk或isamchk作合使用。但是,外部鎖定在某些系統(tǒng)中是禁用的,因為他不能可靠的進行工作。對運行myisamchk或isamchk所選擇的過程取決于服務器是否能使用外部鎖定。如果不使用,則必修使用內(nèi)部鎖定協(xié)議。

如果服務器用--skip-locking選項運行,則外部鎖定禁用。該選項在某些系統(tǒng)中是缺省的,如Linux。可以通過運行MySQL數(shù)據(jù)庫表admin variables命令確定服務器是否能夠使用外部鎖定。檢查skip_locking變量的值并按以下方法進行:

如果skip_locking為off,則外部鎖定有效您可以繼續(xù)并運行人和一個實用程序來檢查表。服務器和實用程序?qū)⒑献鲗Ρ磉M行訪問。但是,運行任何一個實用程序之前,應該使用MySQLadmin flush-tables。為了修復表,應該使用表的修復鎖定協(xié)議。

如果skip_locaking為on,則禁用外部鎖定,所以在myisamchk或isamchk檢查修復表示服務器并不知道,***關(guān)閉服務器。如果堅持是服務器保持開啟狀態(tài),月確保在您使用此表示沒有客戶機來訪問它。必須使用卡黨的鎖定協(xié)議告訴服務器是該表不被其他客戶機訪問。

檢查表的鎖定協(xié)議

本節(jié)只介紹如果使用表的內(nèi)部鎖定。對于檢查表的鎖定協(xié)議,此過程只針對表的檢查,不針對表的修復。

1.調(diào)用MySQL發(fā)布下列語句:

 

  1. $MySQL –u root –p db_namemysql>LOCK TABLE tbl_name READ;mysql>FLUSH TABLES; 

該鎖防止其它客戶機在檢查時寫入該表和修改該表。FLUSH語句導致服務器關(guān)閉表的文件,它將刷新仍在告訴緩存中的任何為寫入的改變。

2.執(zhí)行檢查過程

 

  1. $myisamchk tbl_name$ isamchk tbl_name 

3.釋放表鎖

MySQL>UNLOCK TABLES;

如果myisamchk或isamchk指出發(fā)現(xiàn)該表的問題,將需要執(zhí)行表的修復。

修復表的鎖定協(xié)議

這里只介紹如果使用表的內(nèi)部鎖定。修復表的鎖定過程類似于檢查表的鎖定過程,但有兩個區(qū)別。***,你必須得到寫鎖而非讀鎖。由于你需要修改表,因此根本不允許客戶機對其進行訪問。第二,必須在執(zhí)行修復之后發(fā)布FLUSH TABLE語句,因為myisamchk和isamchk建立的新的索引文件,除非再次刷新改表的高速緩存,否則服務器不會注意到這個改變。本例同樣適合優(yōu)化表的過程。

1.調(diào)用MySQL數(shù)據(jù)庫表發(fā)布下列語句:

 

  1. $MySQL –u root –p db_namemysql>LOCK TABLE tbl_name WRITE;mysql>FLUSH TABLES; 

2.做數(shù)據(jù)表的拷貝,然后運行myisamchk和isamchk:

 

  1. $cp tbl_name.* /some/other/dir$myisamchk --recover tbl_name$ isamchk --recover tbl_name 

recover選項只是針對安裝而設置的。這些特殊選項的選擇將取決與你執(zhí)行修復的類型。

3.再次刷新高速緩存,并釋放表鎖:

 

  1. MySQL>FLUSH TABLES;mysql>UNLOCK TABLES; 

以上的相關(guān)內(nèi)容就是對MySQL數(shù)據(jù)庫表進行鎖定詳解的介紹,望你能有所收獲。

【編輯推薦】

  1. IPTV會否是分眾購對象
  2. 我國IPTV研究目全球領(lǐng)先
  3. 3G與IPTV是發(fā)展大方向
  4. 我國IPTV研究目全球領(lǐng)先
  5. 3G與IPTV是發(fā)展大方向

 

責任編輯:佚名 來源: 博客園
相關(guān)推薦

2009-02-02 16:50:34

數(shù)據(jù)庫表的鎖定MySQL

2010-02-04 17:42:15

Android數(shù)據(jù)庫

2011-05-18 13:16:21

MySQL數(shù)據(jù)庫鎖定

2009-02-02 13:43:19

故障檢測數(shù)據(jù)庫

2011-05-25 00:00:00

數(shù)據(jù)庫設計

2009-07-15 18:01:53

Jython數(shù)據(jù)庫

2023-09-14 23:05:57

? ?MySQL數(shù)據(jù)庫

2021-07-28 15:44:52

Java開發(fā)數(shù)據(jù)庫

2018-02-26 20:00:00

編程語言JavaMySQL

2010-08-17 09:48:40

DB2 分區(qū)數(shù)據(jù)庫

2009-02-02 17:21:58

日志文件維護MySQL日志文件

2020-09-07 12:59:10

NoSQL數(shù)據(jù)庫數(shù)據(jù)

2018-09-17 16:12:03

數(shù)據(jù)庫數(shù)據(jù)恢復SQL Server

2022-12-01 14:02:02

MySQL數(shù)據(jù)文件

2010-06-01 16:35:43

MySQL數(shù)據(jù)庫

2018-02-08 18:16:39

數(shù)據(jù)庫MySQL鎖定機制

2022-06-29 09:14:45

PolarDB云原生數(shù)據(jù)庫

2010-05-18 11:04:11

MySQL數(shù)據(jù)庫

2018-05-10 17:18:59

數(shù)據(jù)庫MySQL密碼

2010-09-24 18:47:23

SQL數(shù)據(jù)分頁
點贊
收藏

51CTO技術(shù)棧公眾號