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