老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

MySQL中怎么鎖定數據表-創新互聯

這篇文章將為大家詳細講解有關MySQL中怎么鎖定數據表,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

創新互聯建站主要從事網頁設計、PC網站建設(電腦版網站建設)、wap網站建設(手機版網站建設)、自適應網站建設、程序開發、網站優化、微網站、小程序定制開發等,憑借多年來在互聯網的打拼,我們在互聯網網站建設行業積累了豐富的成都網站建設、網站建設、網站設計、網絡營銷經驗,集策劃、開發、設計、營銷、管理等多方位專業化運作于一體。

鎖定表的方法

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

服務器由兩種表的鎖定方法:

1.內部鎖定

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

語法:

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

解鎖表:UNLOCK TABLES

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

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

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

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

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

2.外部鎖定

服務器還可以使用外部鎖定(文件級鎖)來防止其它程序在服務器使用表時修改文件。通常,在表的檢查操作中服務器將外部鎖定與myisamchk或 isamchk作合使用。但是,外部鎖定在某些系統中是禁用的,因為他不能可靠的進行工作。對運行myisamchk或isamchk所選擇的過程取決于服務器是否能使用外部鎖定。如果不使用,則必修使用內部鎖定協議。
如果服務器用--skip-locking選項運行,則外部鎖定禁用。該選項在某些系統中是缺省的,如。可以通過運行admin variables命令確定服務器是否能夠使用外部鎖定。檢查skip_locking變量的值并按以下方法進行:

◆ 如果skip_locking為off,則外部鎖定有效您可以繼續并運行人和一個實用程序來檢查表。服務器和實用程序將合作對表進行訪問。但是,運行任何一個實用程序之前,應該使用mysqladmin flush-tables。為了修復表,應該使用表的修復鎖定協議。

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

檢查表的鎖定協議

本節只介紹如果使用表的內部鎖定。對于檢查表的鎖定協議,此過程只針對表的檢查,不針對表的修復。

1.調用mysql發布下列語句:


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


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

2.執行檢查過程


$myisamchk tbl_name$ isamchk tbl_name


3.釋放表鎖


mysql>UNLOCK TABLES;


如果myisamchk或isamchk指出發現該表的問題,將需要執行表的修復。

修復表的鎖定協議

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

1.調用mysql發布下列語句:


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


2.做數據表的拷貝,然后運行myisamchk和isamchk:


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


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

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


mysql>FLUSH TABLES;mysql>UNLOCK TABLES;

關于MySQL中怎么鎖定數據表就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


標題名稱:MySQL中怎么鎖定數據表-創新互聯
瀏覽路徑:http://www.xueling.net.cn/article/djpicc.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 亚洲一区二区三区在线观看精品中文 | 2017男人天堂手机在线 | 日韩国产欧美一区二区 | 一区二区日韩av | 欧美国产精品久久久久久免费 | 国产在线欧美日韩精品一区 | 男女免费在线观看 | 搜查官中文字幕一区二区 | 国产精品影视在线观看 | 国产成人精品一区二区尿失禁 | 精品久久久久久久久久ntr影视 | 欧洲熟妇色xxxx欧美老妇软件 | 国产胸大一区二区三区粉嫩思欲 | 中文字幕人 | 青青草娱乐视频 | 国产在线播放你懂的 | 成全视频在线观看大全腾讯地图 | 欧美久操视频 | 久久精品国产77777蜜臀 | 免费看片A级毛片免费看 | 色老板最新地址入口处 | 中文高清少妇免费 | 日日日操操 | 国产人成一区二区三区影院 | www日本黄色 | 国产精品视频免费观看www | 亚洲日韩无砖专区一中文字目 | 中文字幕一区在线无码视频 | 成年女人看片免费视频播放人 | 免费看一级黄色 | 日韩成人午夜 | 97国产影院 | 国产妇女乱码一区二区三区 | 色综合天天天天做夜夜夜夜做 | 国产一级一片免费播放 | 91精品一区二区三区综合 | 国产日韩精品一区在线观看播放 | 国产传媒果冻天美传媒怎么入职 | 久久国产成人午夜av影院武则天 | 麻豆高清免费国产一区 | 大象一区 |