避免mysql死鎖的方法:1、以固定的順序存取表格和行;2、大事務更傾向於死鎖,如果業務允許,將大事務拆小;3、在同一個事務中,盡可能做到一次鎖定所需的所有資源,減少死鎖機率;4、降低隔離等級;5、為表格添加合理的索引。
如何盡可能避免死鎖:
#1、以固定的順序存取表格和行。例如兩個更新資料的事務,事務A 更新資料的順序 為1,2;事務B更新資料的順序為2,1。這樣更可能會造成死鎖。
2、大事務拆小。大事務更傾向於死鎖,如果業務允許,將大事務拆小。
3、在同一個交易中,盡可能做到一次鎖定所需的所有資源,減少死鎖機率。
4、降低隔離等級。如果業務允許,將隔離等級調低也是較好的選擇,例如將隔離等級從RR調整為RC,可以避免掉很多因為gap鎖定造成的死鎖。
5、為表格新增合理的索引。可以看到如果不走索引將會為表的每一行記錄添加上鎖,死鎖的機率大大增大。
以上是怎麼樣避免mysql死鎖的詳細內容。更多資訊請關注PHP中文網其他相關文章!