【MySQL】-MVCC多版本并发控制

1、当前读

select 不加锁状态,当前读=快照读

2、快照读

在select加锁下,读取数据后,形成快照。每个事务都会形成自己的快照内容

复制代码
SELECT * FROM xx_table LOCK IN SHARE MODE;

SELECT * FROM xx_table FOR UPDATE;

INSERT INTO xx_table ...

DELETE FROM xx_table ...

UPDATE xx_table ...

仅RC、RR支持快照读

3、RC级别

在事务中,每次select 都会读取最新记录,形成快照,产生不可重复读问题

4、RR级别

在事务中,只有第一次select读取最新数据,形成快照。

在该事务中更新内容,然后更新快照。后面直接读取快照内容。

5、行记录存在隐藏字段

1、db_row_id:如果表中没有主键索引,则创建默认主键ID

2、db_trx_id:当前数据最近一次修改的事务ID

3、roll_prt:回滚指针,记录上一次的版本,引用 undolog 的上一个版本的快照地址

6、Read View

多事务下

用于解决本次事务应该看到哪个快照,不应该看到哪个快照。

主要属性说明:

●trx_ids,系统当前未提交的事务 ID 的列表。

●low_limit_id,应该分配给下一个事务的id 值。

●up_limit_id,未提交的事务中最小的事务 ID。

●creator_trx_id,创建这个 Read View 的事务 ID。

相关推荐
abc123456sdggfd16 分钟前
HTML5中Vuex持久化插件中WebStorage的底层配置
jvm·数据库·python
pele19 分钟前
Go语言如何发GET请求_Go语言HTTP GET请求教程【总结】
jvm·数据库·python
weixin_5806140019 分钟前
Go 语言中 go install 命令的正确用法与常见误区详解
jvm·数据库·python
qq_6543669820 分钟前
Bootstrap 5移除jQuery依赖 Bootstrap 5如何不使用jQuery
jvm·数据库·python
m0_6765443822 分钟前
CSS如何实现元素悬浮在页面底部_利用fixed定位与底部间距
jvm·数据库·python
weixin_5689960623 分钟前
Redis怎样监控当前发生了多少次内存驱逐
jvm·数据库·python
2301_7965885024 分钟前
CSS如何制作导航栏平滑移动_使用transition与left属性
jvm·数据库·python
2301_8038756124 分钟前
C#怎么清空Dictionary字典_C#如何管理内存集合【基础】
jvm·数据库·python
Greyson125 分钟前
CSS项目开发如何提速_应用BEM规范建立可复用的样式库.txt
jvm·数据库·python