網(wǎng)站首頁 編程語言 正文
文章目錄
- 概述
- 隔離級別
- 實現(xiàn)
- redo log
- 案例
- undo log
概述
隔離級別
實現(xiàn)
redo log
redo log
叫做重做日志,是用來實現(xiàn)事務(wù)的持久性。
該日志有兩部分組成:重做日志緩沖(redo log buffer
)和重做日志文件(redo log
)。
前者在內(nèi)存中,后者在磁盤中。當事務(wù)提交之后會把所有修改信息存到該日志中,用于在刷新臟頁到磁盤時,或者發(fā)生錯誤時,進行數(shù)據(jù)恢復(fù)使用。
案例
在銀行轉(zhuǎn)賬操作中使用事務(wù),從銀行賬戶表中轉(zhuǎn)出2000元到理財賬戶表中。
數(shù)據(jù)準備
select version();
8.0.30
create database if not exists db_test default character set utf8mb4 collate utf8mb4_0900_ai_ci;
use db_test;
create table if not exists tb_bank
(
id int primary key auto_increment,
name varchar(20) not null comment '賬戶名稱',
balance int not null comment '賬單資金'
) engine = innodb
default charset = utf8mb4
collate = utf8mb4_0900_ai_ci
comment '銀行賬戶表';
create table if not exists tb_finance
(
id int primary key auto_increment,
name varchar(20) not null comment '賬戶名稱',
account int not null comment '賬單資金'
) engine = innodb
default charset = utf8mb4
collate = utf8mb4_0900_ai_ci
comment '理財賬戶表';
insert into tb_bank
values (null, 'Tom', 10000);
insert into tb_finance
values (null, 'Tom', 0);
數(shù)據(jù)驗證
select * from tb_bank;
1,Tom,10000
select * from tb_finance;
1,Tom,0
執(zhí)行事務(wù)操作
start transaction;
select balance from tb_bank where name = 'Tom';
-- 生成重做日志 balance = 8000
update tb_bank set balance = balance - 2000 where name = 'Tom';
-- 生成重做日志 account = 8000
update tb_finance set account = account + 2000 where name = 'Tom';
commit ;
流程
mysql 為了提升性能把每次修改的數(shù)據(jù)同步到磁盤,而是會先存到 Buffer Pool
中,把這個當作緩存,然后使用后臺的線程將緩存刷新到磁盤。
當在執(zhí)行刷新時,宕機或者斷電,可能會丟失部分數(shù)據(jù)。所以引入 redo log
來記錄已成功提交事務(wù)的修改信息,并且在事務(wù)提交時會把 redo log
持久化到磁盤,系統(tǒng)重啟后再讀取 redo log
恢復(fù)最新數(shù)據(jù)。
redo log 用于恢復(fù)數(shù)據(jù),保障已提交事務(wù)的持久化特性。
undo log
undo log
叫做回滾日志,用戶記錄數(shù)據(jù)被修改前的信息,作用包含兩個:提供回滾和 MVCC
(多版本并發(fā)控制)。
與 redo log
相反,undo log
記錄被修改前的信息。 undo log
主要記錄數(shù)據(jù)的邏輯變化,可以在發(fā)生錯誤時將之前的記錄的邏輯變化進行回滾。
原文鏈接:https://blog.csdn.net/weixin_44756627/article/details/126413498
相關(guān)推薦
- 2022-05-31 關(guān)于k8s?使用?Service?控制器對外暴露服務(wù)的問題_云其它
- 2022-12-09 C#調(diào)用Windows的API實現(xiàn)窗體動畫_C#教程
- 2023-06-21 Docker安裝部署Redis數(shù)據(jù)庫的實現(xiàn)步驟_docker
- 2022-04-03 用Python實現(xiàn)屏幕截圖詳解_python
- 2022-07-12 BlockingQueue阻塞隊列原理以及實現(xiàn)
- 2022-06-19 Python?matplotlib實現(xiàn)條形統(tǒng)計圖_python
- 2022-07-09 Python如何保留float類型小數(shù)點后3位_python
- 2022-10-03 如何在python中實現(xiàn)capl語言里的回調(diào)函數(shù)(推薦)_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支