網(wǎng)站首頁 編程語言 正文
文章目錄
- 概述
- 隔離級別
- 實(shí)現(xiàn)
- redo log
- 案例
- undo log
概述
隔離級別
實(shí)現(xiàn)
redo log
redo log
叫做重做日志,是用來實(shí)現(xiàn)事務(wù)的持久性。
該日志有兩部分組成:重做日志緩沖(redo log buffer
)和重做日志文件(redo log
)。
前者在內(nèi)存中,后者在磁盤中。當(dāng)事務(wù)提交之后會把所有修改信息存到該日志中,用于在刷新臟頁到磁盤時,或者發(fā)生錯誤時,進(jìn)行數(shù)據(jù)恢復(fù)使用。
案例
在銀行轉(zhuǎn)賬操作中使用事務(wù),從銀行賬戶表中轉(zhuǎn)出2000元到理財賬戶表中。
數(shù)據(jù)準(zhǔn)備
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ù)驗(yàn)證
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
中,把這個當(dāng)作緩存,然后使用后臺的線程將緩存刷新到磁盤。
當(dāng)在執(zhí)行刷新時,宕機(jī)或者斷電,可能會丟失部分?jǐn)?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ā)生錯誤時將之前的記錄的邏輯變化進(jìn)行回滾。
原文鏈接:https://blog.csdn.net/weixin_44756627/article/details/126413498
相關(guān)推薦
- 2023-05-08 Docker中的compose簡介_docker
- 2023-07-13 替換字符串中的任意字符及正則隱藏手機(jī)號中間四位
- 2023-03-15 Native層消息機(jī)制深入探究實(shí)例解析_Android
- 2022-10-30 使用AVFoundation實(shí)現(xiàn)視頻錄制詳解_IOS
- 2022-11-26 Redis下載部署并加入idea應(yīng)用的小結(jié)_Redis
- 2022-11-14 C語言?ffmpeg與sdl實(shí)現(xiàn)播放視頻同時同步時鐘詳解_C 語言
- 2022-09-26 nodemon安裝在開發(fā)環(huán)境(非全局安裝)報錯解決【兩種方式】
- 2022-05-17 springcloud feign本地微服務(wù)之間的相互調(diào)用
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(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被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支