亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

mysql 并發修改問題,批量修改問題,可能產生死鎖問題萬分感謝

mysql 并發修改問題,批量修改問題,可能產生死鎖問題萬分感謝

慕村9548890 2019-06-19 09:49:47
問題描述需要批量更新一個字段值,updatetablesetxxx=xxx+awherea=?andb=?ab有索引,還有另外一個主鍵索引會有并發的情況,可以不考慮事務回滾相關代碼//請把代碼文本粘貼到下方(請勿用圖片代替代碼)publicvoidtest(Listlist){for(Objecto:list){updatetablesetxxx=xxx+awherea=?andb=?}}這個方法在不加事務注解情況下,在并發執行時,xxx字段,在我理解是不會有臟數據的吧?但是有可能會跟其他update語句產生死鎖對嗎?
查看完整描述

2 回答

?
小唯快跑啊

TA貢獻1863條經驗 獲得超2個贊

updatetablesetxxx=xxx+awherea=?andb=?
字段a、b都有索引的話,這個更新不會鎖整張表(只會鎖住更新的那一行數據),產生死鎖需要有靜態條件,比如:
操作A:
updatetableasetxxx=xxx+awherea=1andb=1
updatetablebsetxxx=xxx+a...
操作B:
updatetablebsetxxx=xxx+a...
updatetableasetxxx=xxx+awherea=1andb=1
這時,就有可能產生死鎖了...
                            
查看完整回答
反對 回復 2019-06-19
?
慕妹3242003

TA貢獻1824條經驗 獲得超6個贊

字段a、b都有索引,更新時候通過索引已經明確到要加鎖的范圍了,不會有死鎖的。假如你還有另外一個更新語句,是表鎖的話,那可能就會出現死鎖了。
                            
查看完整回答
反對 回復 2019-06-19
  • 2 回答
  • 0 關注
  • 414 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號