作者简介:肖泽凡,腾讯TEG研发管理部小小后台攻城狮一枚,负责腾讯敏捷产品研发平台TAPD的基础功能的开发和维护,热爱技术,喜欢分享,文章首次发表于SegmentFault,博客名“X先生”,欢迎与我交流~
锁是为了解决并发环境下资源竞争的手段,其中乐观并发控制,悲观并发控制和多版本并发控制是数据库并发控制主要采用的技术手段,而MySQL中的锁就是其中的悲观并发控制。
MySQL中的锁有很多种类,我们可以按照下面方式来进行分类。
一、按读写
二、按粒度
行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。行锁总是逐步获得的,因此会出现死锁。
页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。
mysql>select *from users;
+----+------+-----+
|id|name | age |
+----+------+-----+
| 1| a |1 |
| 2| a |1 |
| 3| a |1 |
| 4| a |1 |
| 5| a |1 |
+----+------+-----+
复制
mysql> begin;
Query OK, 0 rows affected (0.00sec)
mysql> lock tables userswrite;
Query OK, 0 rows affected (0.00sec)
mysql> show engine innodb status\G
...
------------
TRANSACTIONS
------------
Trx id counter 4863
Purge donefortrx's n:o <4862undo n:o <0state: running but idle
History list length 911
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION 281479760456232,not started
mysql tables in use 1, locked 1 ###############注意这里
0lock struct(s),heap size 1136, 0 row lock(s)
...
复制
## 先解锁上次的表锁
mysql> unlock tables;
Query OK, 0 rows affected (0.00sec)
mysql> commit;
Query OK, 0 rows affected (0.00sec)
mysql> begin;
Query OK, 0 rows affected (0.00sec)
mysql>select *from users where name ='a'for update;
mysql> show engine innodb status\G
...
------------
TRANSACTIONS
------------
Trx id counter 4864
Purge donefor trx'sn:o <4862undo n:o <0state: running but idle
History list length 911
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION 4863,ACTIVE 37 sec
2lock struct(s),heap size 1136, 6 row lock(s) ###############注意这里
...
复制
mysql> delete from users where idin(2,3,4);
Query OK, 3 rows affected (0.00sec)
mysql> commit;
Query OK, 0 rows affected (0.00sec)
mysql> begin;
Query OK, 0 rows affected (0.00sec)
mysql>select *from users where name ='a'for update;
mysql> show engine innodb status\G
...
------------
TRANSACTIONS
------------
Trx id counter 4870
Purge donefortrx's n:o <4869undo n:o <0state: running but idle
History list length 914
LIST OF TRANSACTIONS FOR EACH SESSION:
---TRANSACTION 4869,ACTIVE 9 sec
2lock struct(s),heap size 1136, 3 row lock(s) ###############注意这里
...
复制
mysql> selectENGINE_TRANSACTION_ID,LOCK_TYPE,LOCK_MODE from performance_schema.data_lockswhere ENGINE_TRANSACTION_ID in (你的事务id);
+-----------------------+-----------+-----------+
| ENGINE_TRANSACTION_ID | LOCK_TYPE | LOCK_MODE |
+-----------------------+-----------+-----------+
| 4889 |TABLE | IX |
| 4889 |RECORD | X |
| 4889 |RECORD | X |
| 4889 |RECORD | X |
+-----------------------+-----------+-----------+
10 rows in set (0.00 sec)
复制
三、参考资料
文章转载自腾讯云数据库,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
3297次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
907次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
535次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
457次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
383次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
351次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
303次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
297次阅读
2025-05-06 14:40:00
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
293次阅读
2025-04-28 11:01:25
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
291次阅读
2025-04-30 12:17:54