MVCC、锁

1. mysql 锁

1事务A进行创建表

sql 复制代码
-- ------------------------------------------------------------------------------1.创建表
-- 创建测试表
CREATE TABLE IF NOT EXISTS test_lock (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50),
    age INT
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
-- ------------------------------------------------------------------------------2.插入数据
-- 插入初始数据
INSERT INTO test_lock (name, age) VALUES ('Alice', 20), ('Bob', 25), ('Charlie', 30);


-- ----------------------------------------------------------------------------3.隔离级别
-- 1. 查看当前隔离级别
SELECT @@transaction_isolation; 
-- (旧版本MySQL可能是 @@tx_isolation)
-- 2. 设置当前会话的隔离级别 (四种任选其一)
-- 选项 A: 读未提交
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
-- 选项 B: 读已提交 (推荐用于高并发写场景)
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
-- 选项 C: 可重复读 (MySQL 默认,推荐用于强一致性场景)
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
-- 选项 D: 串行化 (性能极差,仅测试用)
SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
-- 3. 再次确认是否设置成功
SELECT @@transaction_isolation;

-- -------------------------------------------------------------------------------------4.窗口A,隐式枷锁
-- 设置隔离级别为 RR
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
START TRANSACTION;
-- 执行更新,此时自动给 id=1 的行加了排他锁
UPDATE test_lock SET age = 21 WHERE id = 1; 

COMMIT

-- ⚠️ 注意:此时不要执行 COMMIT 或 ROLLBACK,让事务挂着!

--  ---------------------------------------------------------------------------------------5.显式加锁

START TRANSACTION;
-- 这行代码会立即给 id=1 加上排他锁,即使你只是读取
SELECT * FROM test_lock WHERE id = 1 FOR UPDATE;
-- 此时其他事务无法更新或删除 id=1
COMMIT

-- ---------------------------------------------------------------------6.显式加锁
START TRANSACTION;
-- MySQL 8.0+ 写法
SELECT * FROM test_lock WHERE id = 1 FOR SHARE;
-- MySQL 5.7 及以前写法
-- SELECT * FROM test_lock WHERE id = 1 LOCK IN SHARE MODE;

2.事务B:尝试在事务A持有锁的情况下,查询,验证锁

sql 复制代码
-- -----------------------------------------------------1. 事务B的查询
-- 事务B
START TRANSACTION;

-- 尝试更新同一行,这里会被阻塞(卡住),直到窗口1提交或回滚
UPDATE test_lock SET age = 22 WHERE id = 1;
COMMIT

-- 如果卡住了,说明锁生效了!




-- ----------------------------------------------------2. 基础锁的查询
SELECT
  OBJECT_NAME,
  LOCK_TYPE,
  LOCK_MODE,
  LOCK_STATUS,
  LOCK_DATA,
  THREAD_ID
FROM performance_schema.data_locks;

得到结果

2.RR RC级别下的读取结果不一致

3.mysql中的事务自动提交

📌 先搞懂 MySQL 的「自动提交」规则(关键)

MySQL 默认开启 autocommit=ON(自动提交),核心规则:

  1. 无显式事务时 :每一条 DML 语句(INSERT/UPDATE/DELETE)都会被当成独立事务 ,执行后立即自动提交 ,无需手动写 COMMIT
  2. 显式事务时 :只有写了 START TRANSACTION/BEGIN,才会关闭本次会话的自动提交,直到执行 COMMIT/ROLLBACK 后恢复。
相关推荐
F1FJJ2 小时前
Shield CLI v0.3.0:插件系统上线,首发 MySQL Web 管理
网络·数据库·网络协议·mysql·容器·golang
Seven972 小时前
MySQL锁机制:从全局锁到行级锁的深度解读
mysql
一叶飘零_sweeeet2 小时前
击穿 MySQL 事务隔离级别:底层实现原理 + 生产级架构选型避坑指南
数据库·mysql·架构·mysql事务隔离级别
计算机学姐3 小时前
基于SpringBoot+Vue的家政服务预约系统【个性化推荐+数据可视化】
java·vue.js·spring boot·后端·mysql·信息可视化·java-ee
gechunlian883 小时前
数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(一).创建基础表
数据库·mysql·oracle
堕2743 小时前
MySQL数据库《基础篇--数据库JDBC编程》
数据库·mysql
小张贼嚣张3 小时前
SQL 正则表达式详解:语法、函数与实战案例(MySQL/Oracle通用)
mysql·oracle·正则表达式
身如柳絮随风扬12 小时前
MySQL核心知识
数据库·mysql
551只玄猫12 小时前
【数据库原理 实验报告1】创建和管理数据库
数据库·sql·学习·mysql·课程设计·实验报告·数据库原理