一条SQL更新语句是如何执行的?
生活随笔
收集整理的這篇文章主要介紹了
一条SQL更新语句是如何执行的?
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
update T set c=c+1 where ID=2;
執(zhí)行器先找引擎取 ID=2 這一行。ID 是主鍵,引擎直接用樹搜索找到這一行。如果 ID=2 這一行所在的數(shù)據(jù)頁本來就在內(nèi)存中,就直接返回給執(zhí)行器;否則,需要先從磁盤讀入內(nèi)存,然后再返回。 執(zhí)行器拿到引擎給的行數(shù)據(jù),把這個值加上 1,比如原來是 N,現(xiàn)在就是 N+1,得到新的一行數(shù)據(jù),再調(diào)用引擎接口寫入這行新數(shù)據(jù)。 引擎將這行新數(shù)據(jù)更新到內(nèi)存中,同時將這個更新操作記錄到 redo log 里面,此時 redo log 處于 prepare 狀態(tài)。然后告知執(zhí)行器執(zhí)行完成了,隨時可以提交事務(wù)。 執(zhí)行器生成這個操作的 binlog,并把 binlog 寫入磁盤。 執(zhí)行器調(diào)用引擎的提交事務(wù)接口,引擎把剛剛寫入的 redo log 改成提交(commit)狀態(tài),更新完成。
?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
?
?
總結(jié)
以上是生活随笔為你收集整理的一条SQL更新语句是如何执行的?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 存储引擎放弃使用索引的方式
- 下一篇: Mysql俩种表级锁