当前位置: 首页 > MySQL数据库

怎么使用innodb行锁

时间:2026-01-28 14:10:41

三种级别

record lock  锁住某一行记录  

gap lock     锁住某一段范围中的记录 

next key lock 是前两者效果的叠加
实验环境
mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)
mysql> select * from t;
+------+
| id   |
+------+
|    2 |
|    8 |
|   19 |
|   22 |
+------+
mysql> create index t_ind on t(id);
Query OK, 0 rows affected (8.52 sec)
 同时打开两个会话,并打开事物
会话一
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> delete from t where id=19;
Query OK, 1 row affected (0.00 sec)
会话二
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> insert into t values(55);
Query OK, 1 row affected (0.00 sec)
mysql> insert into t values(10);
^C^C -- query aborted
ERROR 1317 (70100): Query execution was interrupted
mysql> 
mysql> insert into t values(1);
Query OK, 1 row affected (0.00 sec)

mysql> insert into t values(12);
^C^C -- query aborted
ERROR 1317 (70100): Query execution was interrupted
mysql> 
会话二说明8-22之间被锁住了,无法插入数据.这就是gap lock                                                      

取消gap lock
修改事物的隔离级别到READ COMMITTED                                                                               


上一篇:MySQL mvcc奇怪的现象分析
下一篇:MySQL慢查询日志举例分析
innodb
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素