MySQL中update一条record的过程
生活随笔
收集整理的這篇文章主要介紹了
MySQL中update一条record的过程
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
在MySQL中,update是原地更新數(shù)據(jù),原地更新數(shù)據(jù),原地更新數(shù)據(jù)。重要的事情說3遍。這是不同于PGSQL的。
update的具體過程是:
(1)、先對該條record對應(yīng)的索引加X鎖
(2)、將修改后的數(shù)據(jù)寫入到redo.log中
(3)、將修改之前的數(shù)據(jù)備份到undo.log中
(4)、備份完畢,原地更新數(shù)據(jù),修改txid,將roll_ptr指向undo.log中該條記錄的備份,最后提交事務(wù)tx
(5)、提交事務(wù)tx過程中,服務(wù)器突然宕機(jī),再次重啟時,重放redo.log中的日志進(jìn)行數(shù)據(jù)的修復(fù)。
如果在還未提交tx之前服務(wù)器突然宕機(jī)了,但是對應(yīng)的dirty page已經(jīng)flush到磁盤文件中,那么再次啟機(jī)時,可以根據(jù)undo.log中的日志進(jìn)行數(shù)據(jù)的恢復(fù)
總結(jié)
以上是生活随笔為你收集整理的MySQL中update一条record的过程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 两路归并排序
- 下一篇: linux cmake编译源码,linu