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