大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

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

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

更新時間:2020-02-03 10:44:01 來源:動力節(jié)點 瀏覽2722次


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


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


  全局鎖


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


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


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


  表級鎖


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


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


  我們可以使用unlocktables主動釋放鎖,如果沒有使用的話,在客戶端斷開的時候自動釋放。


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


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


  MDL鎖有以下兩個特點:


  讀鎖之間不互斥,因此你可以有多個線程同時對一張表增刪改查。


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


  行級鎖


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


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


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


  InnoDB引擎實現(xiàn)了行級鎖,InnoDB存儲引擎中實現(xiàn)了兩種標準的行級鎖:


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


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


  共享鎖是兼容鎖,就是當一個事務(wù)已經(jīng)獲得了行r的共享鎖,其他事務(wù)可以立即獲得行r的共享鎖,因為讀并未改變行r的數(shù)據(jù)。


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


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


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


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


  相關(guān)視頻教程


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


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


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


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


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


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


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


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


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


提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 四虎永久免费地址 | 五月天婷亚洲天综合网精品偷 | 麻豆一区二区三区在线观看 | 日本在线一卡二卡毛片 | 免费观看毛片视频 | 成人 日韩 在线 | 99久久成人 | 午夜免费 | 亚洲精品一区二区三区国产 | 免费看日韩欧美一级毛片 | 97视频在线观看免费视频 | 欧美一级级a在线观看 | 奇米影视4色 | 女孕学护士一级毛片 | 日韩毛片免费 | 国产精品美女久久久久网 | 四虎国产精品免费观看 | 四虎最新影院 | 亚洲精品一区二区三区在线看 | 免费观看黄色小视频 | 一区二区三区网站在线免费线观看 | 日本欧美在线观看 | 嘿咻视频在线观看 | 亚洲图片欧美另类 | 青青青青久久精品国产一百度 | 狠狠久久久久综合网 | 久久欧美 | 资源站在线 | 免费aa毛片 | 美女被视频在线看九色 | 卡通动漫亚洲综合 | 日本护士一级毛片在线播放 | 欧美一区二区三区视频在线观看 | 日韩免费高清一级毛片久久 | 国产成人久久精品麻豆二区 | 国产视频福利在线 | 免费看国产精品久久久久 | 69香蕉视频 | 国产大尺度视频 | 免费视频爰爱太爽了 | 亚洲精品片 |