MySQL中是如何insert数据的

正常insert数据,MySQL并不会显式加锁,而是通过聚簇索引的trx_id索引作为隐式锁来保护记录的。比如两个事务对一个非唯一的索引情况添加,会造成幻读
在这里插入图片描述
但在某些特殊情况下,隐式锁会转变为显式锁

  • 记录之间有间隙锁
  • insert的记录与已有记录的唯一索引冲突

记录之间有间隙锁

每插入一条新记录,都需要看一下待插入记录的下一条记录上是否已经被加了间隙锁,如果已加间隙锁,此时会生成一个插入意向锁,然后锁的状态设置为等待状态(PS:MySQL 加锁时,是先生成锁结构,然后设置锁的状态,如果锁状态是等待状态,并不是意味着事务成功获取到了锁,只有当锁状态为正常状态时,才代表事务成功获取到了锁),现象就是 Insert 语句会被阻塞。
在这里插入图片描述

# 事务 A
mysql> begin;
Query OK, 0 rows affected (0.01 sec)

mysql> select * from t_order where order_no = 1006 for update;

# 事务 B 插入一条记录
mysql> begin;
Query OK, 0 rows affected (0.01 sec)

mysql> insert into t_order(order_no, create_date) values(1010,now());
### 阻塞状态。。。。

可以看到,事务 B 的状态为等待状态(LOCK_STATUS: WAITING),因为向事务 A 生成的 next-key 锁(记录锁+间隙锁)范围(1005, +∞] 中插入了一条记录,所以事务 B 的插入操作生成了一个插入意向锁(LOCK_MODE: X,INSERT_INTENTION),锁的状态是等待状态,意味着事务 B 并没有成功获取到插入意向锁,因此事务 B 发生阻塞。

遇到唯一键冲突

插入失败,会对这条记录上S型锁

  • 如果主键索引重复,插入新记录的事务会给已存在的主键值重复的聚簇索引记录添加 S 型记录锁。
  • 如果唯一二级索引重复,插入新记录的事务都会给已存在的二级索引列值重复的二级索引记录添加 S 型 next-key 锁。(但假设有这么一种情况,目前表里有二级索引id=1~5的数据记录,事务A插入一个id=6,是可以的,不会被阻塞,也没有上显式锁其实,只有隐式锁。但假设事务B想再插入id=6的数据,A对id=6的隐式锁会升级为显式X锁,B此时相当于想申请id=6的S锁,会被阻塞)

相关推荐

  1. MySQL 数据库 Insert 语句锁机制

    2023-12-09 11:14:02       36 阅读
  2. MySQLinsert ignore into 和 insert into 使用方式

    2023-12-09 11:14:02       36 阅读
  3. mysql insert into...select语句优化

    2023-12-09 11:14:02       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-09 11:14:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-09 11:14:02       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-09 11:14:02       87 阅读
  4. Python语言-面向对象

    2023-12-09 11:14:02       96 阅读

热门阅读

  1. uniapp监听wifi连接状态

    2023-12-09 11:14:02       52 阅读
  2. C/C++——内存管理

    2023-12-09 11:14:02       65 阅读
  3. TCP Keepalive 和 HTTP Keep-Aliv

    2023-12-09 11:14:02       58 阅读
  4. selenium补充

    2023-12-09 11:14:02       60 阅读
  5. SAP UI5 walkthrough step4 XML Views

    2023-12-09 11:14:02       51 阅读
  6. 4-Docker命令之docker port

    2023-12-09 11:14:02       50 阅读
  7. 导出主机上所有docker 镜像并导入到其它主机

    2023-12-09 11:14:02       56 阅读