黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國(guó)咨詢/投訴熱線:400-8080-105
動(dòng)力節(jié)點(diǎn)LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁(yè) 學(xué)習(xí)攻略 Java學(xué)習(xí) MySQL:Java數(shù)據(jù)庫(kù)教程視頻下載

MySQL:Java數(shù)據(jù)庫(kù)教程視頻下載

更新時(shí)間:2020-02-03 10:44:01 來(lái)源:動(dòng)力節(jié)點(diǎn) 瀏覽2728次


  在MySQL數(shù)據(jù)庫(kù)中,鎖有很多種類型,不過(guò)大致可以分為三類:全局鎖、表級(jí)鎖、行級(jí)鎖。這篇文章我們就簡(jiǎn)單的聊一聊這三種鎖。


MySQL:Java數(shù)據(jù)庫(kù)教程視頻下載


  全局鎖


  全局鎖是粒度最大的鎖,基本上也使用不上,就像我們家的大門(mén)一樣,控制這整個(gè)數(shù)據(jù)庫(kù)實(shí)例。全局鎖就是對(duì)整個(gè)數(shù)據(jù)庫(kù)實(shí)例加鎖,讓整個(gè)數(shù)據(jù)庫(kù)處于只讀狀態(tài)。


  MySQL提供了一個(gè)加全局讀鎖的方法,命令是Flushtableswithreadlock(FTWRL),加鎖之后整個(gè)數(shù)據(jù)庫(kù)實(shí)例處于只讀狀態(tài),有關(guān)數(shù)據(jù)操作的命令都會(huì)被掛起阻塞,例如數(shù)據(jù)更新語(yǔ)句、數(shù)據(jù)定義語(yǔ)句、更新類事務(wù)語(yǔ)句等等。


  所以全局鎖一般只用于全庫(kù)備份的時(shí)候,一般只用在不支持一致性讀的存儲(chǔ)引擎做全庫(kù)備份時(shí),比如MyISAM這種不支持一致性讀的存儲(chǔ)引擎做全庫(kù)備份時(shí)需要使用全局鎖,像InnoDB引擎做全庫(kù)備份時(shí)不需要使用全局鎖。


  表級(jí)鎖


  表級(jí)鎖是MySQL最基本的鎖策略,并且是開(kāi)銷最小的策略,它鎖住的不是整個(gè)數(shù)據(jù)庫(kù)實(shí)例,而是一張表。


  表級(jí)鎖跟全局鎖一樣,MySQL數(shù)據(jù)庫(kù)提供了加鎖的命令:locktables…read/write。例如locktablest1read,t2write;命令,則其他線程寫(xiě)t1、讀寫(xiě)t2的語(yǔ)句都會(huì)被阻塞。同時(shí),線程A在執(zhí)行unlocktables之前,也只能執(zhí)行讀t1、讀寫(xiě)t2的操作。連寫(xiě)t1都不允許,自然也不能訪問(wèn)其他表。


  我們可以使用unlocktables主動(dòng)釋放鎖,如果沒(méi)有使用的話,在客戶端斷開(kāi)的時(shí)候自動(dòng)釋放。


  表級(jí)鎖存在一個(gè)問(wèn)題,如果一個(gè)查詢正在遍歷一個(gè)表中的數(shù)據(jù),而執(zhí)行期間另一個(gè)線程對(duì)這個(gè)表結(jié)構(gòu)做變更,刪了一列,那么查詢線程拿到的結(jié)果跟表結(jié)構(gòu)對(duì)不上,肯定是不行的。


  為了解決這個(gè)問(wèn)題,MySQL5.5版本之后引入了元數(shù)據(jù)鎖(metadatalock,MDL),MDL是數(shù)據(jù)庫(kù)自動(dòng)加鎖,當(dāng)對(duì)一個(gè)表做增刪改查操作的時(shí)候,加MDL讀鎖;當(dāng)要對(duì)表做結(jié)構(gòu)變更操作的時(shí)候,加MDL寫(xiě)鎖。


  MDL鎖有以下兩個(gè)特點(diǎn):


  讀鎖之間不互斥,因此你可以有多個(gè)線程同時(shí)對(duì)一張表增刪改查。


  讀寫(xiě)鎖之間、寫(xiě)鎖之間是互斥的,用來(lái)保證變更表結(jié)構(gòu)操作的安全性。因此,如果有兩個(gè)線程要同時(shí)給一個(gè)表加字段,其中一個(gè)要等另一個(gè)執(zhí)行完才能開(kāi)始執(zhí)行。


  行級(jí)鎖


  行級(jí)鎖顧名思義就是針對(duì)數(shù)據(jù)庫(kù)表中的行記錄加鎖,行級(jí)鎖可以最大程度的支持并發(fā)處理,但是同時(shí)也帶來(lái)了最大的鎖開(kāi)銷。


  行級(jí)鎖比較容易理解,比如事務(wù)A更新了一行,而這時(shí)候事務(wù)B也要更新同一行,則必須等事務(wù)A的操作完成后才能進(jìn)行更新。


  行級(jí)鎖是由存儲(chǔ)引擎各自實(shí)現(xiàn)的,也并不是所有的存儲(chǔ)引擎都支持行級(jí)鎖,比如MyISAM引擎就不支持行級(jí)鎖,這意味著MyISAM存儲(chǔ)引擎要控制并發(fā)只能使用表級(jí)鎖。


  InnoDB引擎實(shí)現(xiàn)了行級(jí)鎖,InnoDB存儲(chǔ)引擎中實(shí)現(xiàn)了兩種標(biāo)準(zhǔn)的行級(jí)鎖:


  共享鎖(SLock):允許事務(wù)讀一行


  排它鎖(XLock):允許事務(wù)刪除和更新一行


  共享鎖是兼容鎖,就是當(dāng)一個(gè)事務(wù)已經(jīng)獲得了行r的共享鎖,其他事務(wù)可以立即獲得行r的共享鎖,因?yàn)樽x并未改變行r的數(shù)據(jù)。


  排他鎖是非兼容鎖,如果有事務(wù)想獲取行r的排他鎖,若行r上有共享鎖或者排它鎖,則它必須等其他事務(wù)釋放行r的鎖。


  在InnoDB存儲(chǔ)引擎中,默認(rèn)情況下使用的是一致性的非鎖定行讀,也就是通過(guò)行多版本控制器來(lái)讀取行數(shù)據(jù),我們可以顯示的為行加上共享鎖和排它鎖,語(yǔ)句如下:


  SELECT.....FORUPDATE:對(duì)讀取的行記錄加一個(gè)排它鎖,其他事務(wù)想要在這些行上加任何鎖都會(huì)被阻塞


  SELECT.......LOCKINSHAREMODE:對(duì)讀取的行記錄加一個(gè)共享鎖,其他事務(wù)可以向被鎖定的記錄加共享鎖,但是想要加排它鎖。則會(huì)被阻塞。


  相關(guān)視頻教程


  最實(shí)用的MySQL教程:https://www.wkcto.com/course/37


MySQL:Java數(shù)據(jù)庫(kù)教程視頻下載


       以上就是動(dòng)力節(jié)點(diǎn)Java培訓(xùn)機(jī)構(gòu)小編介紹的“MySQL:Java數(shù)據(jù)庫(kù)教程視頻下載”的內(nèi)容,希望對(duì)大家有幫助,如有疑問(wèn),請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。


  相關(guān)內(nèi)容


  Java編程學(xué)習(xí):MySQL數(shù)據(jù)庫(kù)的學(xué)習(xí)路線


  2020年Java數(shù)據(jù)庫(kù)筆試題大全


  Java數(shù)據(jù)庫(kù)入門(mén)學(xué)習(xí),mysql書(shū)籍推薦


  學(xué)習(xí)Java數(shù)據(jù)庫(kù)增刪查改通用方法


  Java學(xué)習(xí):數(shù)據(jù)庫(kù)學(xué)習(xí)條件查詢和排序


提交申請(qǐng)后,顧問(wèn)老師會(huì)電話與您溝通安排學(xué)習(xí)

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 91精品视频在线播放 | 国产高清天干天天视频 | 国产在线视频你懂的 | 成人短视频在线免费观看 | 日韩免费高清一级毛片 | 国产在线观看色 | 欧美一区二区三区高清视频 | 亚洲精品免费在线视频 | 欧美特级黄色片 | 黄色网一级片 | 99免费在线观看视频 | 欧美亚洲视频 | 日韩高清一区二区 | 成人a在线观看 | 黄色男女视频 | 亚洲日本中文字幕天堂网 | 最近中文字幕无免费视频 | 美女被躁免费视频软件 | 99在线免费观看视频 | www.深夜福利 | 色戒吃奶动态图 | 免费的三级网站 | 国产欧美日韩视频免费61794 | 色综久久天天综合绕视看 | 成年人在线免费看视频 | 国模在线视频一区二区三区 | 黄色在线网站视频 | 久久综合给会久久狠狠狠 | 欧美日韩高清在线观看一区二区 | 一区二区三区波多野结衣 | 日韩在线观看免费 | 成人久久18免费游戏网站 | 亚洲精品免播放器在线观看 | 青青草成人免费 | 国产成人亚洲精品91专区高清 | 色秀视频免费高清网站 | 欧美在线影院 | 一个人看的www播放视频 | 亚洲香蕉视频 | 国产在线精品一区二区三区 | 亚洲剧场午夜在线观看 |