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

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

數(shù)據(jù)庫 MySQL
MySQL數(shù)據(jù)庫是一種小型數(shù)據(jù)庫管理系統(tǒng),功能不是很強大,盡管如此,MySQL數(shù)據(jù)庫還是憑借著自身的優(yōu)點贏得了廣大用戶的青睞,本文中將為大家講解如何鎖定MySQL數(shù)據(jù)庫表。

如果你同時運行表的檢查/修復(fù)程序時,你或許不想讓MySQL服務(wù)器和實用程序同時訪問一個表。如果兩個程序都向表中寫數(shù)據(jù)顯然會造成很大的麻煩,甚至?xí)幸馔馇闆r發(fā)生。如果表正由一個程序?qū)懭?,同時進行讀取的另一個程序也會產(chǎn)生混亂的結(jié)果。本文主要講述如何對MySQL數(shù)據(jù)庫表進行鎖定。

鎖定表的方法

防止客戶機的請求互相干擾或者服務(wù)器與維護程序相互干擾的方法主要有多種。如果你關(guān)閉數(shù)據(jù)庫,就可以保證服務(wù)器和myisamchk和 isamchk之間沒有交互作用。但是停止服務(wù)器的運行并不是一個好注意,因為這樣做會使得沒有故障的數(shù)據(jù)庫和表也不可用。本節(jié)主要討論的過程,是避免服務(wù)器和myisamchk或isamchk之間的交互作用。實現(xiàn)這種功能的方法是對表進行鎖定。

服務(wù)器由兩種表的鎖定方法:

1.內(nèi)部鎖定

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

語法:

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

解鎖表:UNLOCK TABLES

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

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

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

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

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

2.外部鎖定

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

如果服務(wù)器用--skip-locking選項運行,則外部鎖定禁用。該選項在某些系統(tǒng)中是缺省的,如Linux??梢酝ㄟ^運行mysqladmin variables命令確定服務(wù)器是否能夠使用外部鎖定。檢查skip_locking變量的值并按以下方法進行:

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

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

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

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

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

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

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

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

$myisamchk tbl_name$ isamchk tbl_name

3.釋放表鎖

mysql>UNLOCK TABLES;

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

本文中就為大家總結(jié)了上文介紹的這些,上文中涉及到的內(nèi)容就是我要為大家講解的關(guān)于如何鎖定MySQL數(shù)據(jù)庫表的全部講解,希望上文中涉及到的內(nèi)容對大家能夠有所幫助。

 

責任編輯:迎迎 來源: 電腦初學(xué)網(wǎng)
相關(guān)推薦

2023-09-14 23:05:57

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

2009-02-02 16:50:34

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

2010-05-24 14:57:03

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

2009-02-02 13:16:23

修復(fù)數(shù)據(jù)表MySQL

2010-10-13 09:30:45

SQL Server

2022-06-06 08:21:13

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

2010-10-13 11:54:00

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

2018-02-08 18:16:39

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

2011-07-28 17:02:59

MYSQL數(shù)據(jù)庫跨表更新數(shù)據(jù)并合

2010-06-07 13:53:04

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

2009-02-02 13:43:19

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

2010-05-24 14:38:41

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

2011-07-19 11:12:36

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

2019-10-21 08:08:34

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

2019-12-13 10:31:45

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

2018-05-14 16:14:56

數(shù)據(jù)庫MySQL分表與分區(qū)

2010-06-13 10:59:38

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

2017-05-25 10:23:13

數(shù)據(jù)a表b表

2010-10-15 16:20:59

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

2010-06-01 12:51:23

MySQL數(shù)據(jù)庫
點贊
收藏

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