悲觀鎖介紹(百科):
悲觀鎖授翻,正如其名或悲,它指的是對數(shù)據(jù)被外界(包括本系統(tǒng)當(dāng)前的其他事務(wù),以及來自外部系統(tǒng)的事務(wù)處理)修改持保守態(tài)度堪唐,因此巡语,在整個(gè)數(shù)據(jù)處理過程中,將數(shù)據(jù)處于鎖定狀態(tài)淮菠。悲觀鎖的實(shí)現(xiàn)男公,往往依靠數(shù)據(jù)庫提供的鎖機(jī)制(也只有數(shù)據(jù)庫層提供的鎖機(jī)制才能真正保證數(shù)據(jù)訪問的排他性,否則合陵,即使在本系統(tǒng)中實(shí)現(xiàn)了加鎖機(jī)制理澎,也無法保證外部系統(tǒng)不會(huì)修改數(shù)據(jù))逞力。
用法: select … for update;
例如:select * from goods where id = 1 for update;
排他鎖的申請前提:沒有線程對該結(jié)果集中的任何行數(shù)據(jù)使用排他鎖或共享鎖,否則申請會(huì)阻塞糠爬。
for update僅適用于InnoDB寇荧,且必須在事務(wù)塊(BEGIN/COMMIT)中才能生效。在進(jìn)行事務(wù)操作時(shí)执隧,通過“for update”語句揩抡,MySQL會(huì)對查詢結(jié)果集中每行數(shù)據(jù)都添加排他鎖,其他線程對該記錄的更新與刪除操作都會(huì)阻塞镀琉。排他鎖包含行鎖峦嗤、表鎖。
ZT sql悲觀鎖總結(jié)和實(shí)踐 數(shù)據(jù)庫:Mysql中“select ... for update”排他鎖分析