事務(wù)

樂觀鎖相關(guān):

update語句一旦執(zhí)行,在事務(wù)還沒提交前,是會自動把更新的數(shù)據(jù)行鎖定,其他需要鎖定數(shù)據(jù)行的dml操作(例如:select * for update、update、delete)會被掛起等待,等到該數(shù)據(jù)行的鎖被釋放(例如:事務(wù)commit、rollback),才能繼續(xù)執(zhí)行。

hibernate的樂觀鎖實現(xiàn):
實現(xiàn)之一:是通過version字段實現(xiàn),查詢select時候會把version的值取出,然后在update或delete時,會在where條件上加上version = ?(查詢時候的值)。
所以hibernate在更新時語句為:
update tbl_name set column = value , ... where id = ? and version = ?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容