我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql行级锁的工作原理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql行级锁的工作原理

小编给大家分享一下mysql行级锁的工作原理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

mysql行级锁实现原理:1、InnoDB行锁是通过给索引项加锁来实现的,这一点mysql和 oracle不同;2、InnoDB这种行级锁决定,只有通过索引条件来检索数据,才能使用行级锁,否则, 直接使用表级锁。

mysql行级锁实现原理:

锁是在执行多线程时用于强行限定资源访问的同步机制,数据库锁根据锁的粒度可分为行级锁, 表级锁和页级锁

行级锁

行级锁是mysql中粒度最细的一种锁机制,表示只对当前所操作的行进行加锁,行级锁发生冲突 的概率很低,其粒度最小,但是加锁的代价最大。行级锁分为共享锁和排他锁。

特点:

开销大,加锁慢,会出现死锁;锁定粒度最小,发生锁冲突的概率最大,并发性也高;

实现原理:

InnoDB行锁是通过给索引项加锁来实现的,这一点mysql和oracle不同,后者是通过在数据库中 对相应的数据行加锁来实现的,InnoDB这种行级锁决定,只有通过索引条件来检索数据,才能使用行 级锁,否则,直接使用表级锁。

特别注意: 使用行级锁一定要使用索引

举个栗子:

创建表结构

CREATE TABLE `developerinfo` (
  `userID` bigint(20) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `passWord` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`userID`),
  KEY `PASSWORD_INDEX` (`passWord`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

插入数据

INSERT INTO `developerinfo` VALUES ('1', 'liujie', 

'123456');
INSERT INTO `developerinfo` VALUES ('2', 'yitong', '123');
INSERT INTO `developerinfo` VALUES ('3', 'tong', 

'123456');

(1)通过主键索引来查询数据库使用行锁

打开三个命令行窗口进行测试

命令行窗口1命令行窗口2命令行窗口3
mysql> set autocommit = 0;
Query OK, 0 rows affected
mysql> select * from developerinfo where userid = '1' for update;
+-------- +--------+----------+
| userID | name   | passWord |
+--------+-------- +----------+
|      1 | liujie | 123456   |
+-------- +--------+----------+
1 row in set
mysql> set autocommit = 0;
Query OK, 0 rows affected

mysql> select * from developerinfo where userid = '1' for update;

等待

mysql> set autocommit = 0;
Query OK, 0 rows affected
mysql> select * from developerinfo where userid = '3' for update;
+--------+------+----------+
| userID | name | passWord |
+-------- +------+----------+
|      3 | tong | 123456   |
+-------- +------+----------+
1 row in set
mysql> commit;
Query OK, 0 rows affected
mysql> select * from developerinfo where userid = '1' for update;
+--------+-------- +----------+
| userID | name   | passWord |
+--------+-------- +----------+
|      1 | liujie | 123456   |
+-------- +--------+----------+
1 row in set


(2)查询非索引的字段来查询数据库使用行锁

打开两个命令行窗口进行测试

命令行窗口1命令行窗口2
mysql> set autocommit=0;
Query OK, 0 rows affected
mysql> select * from developerinfo where name = 'liujie' for update;
+-------- +--------+----------+
| userID | name   | passWord |
+--------+-------- +----------+
|      1 | liujie | 123456   |
+-------- +--------+----------+
1 row in set
mysql> set autocommit=0;
Query OK, 0 rows affected
mysql> select * from developerinfo where name = 'tong' for update;

等待

mysql> commit;
Query OK, 0 rows affected
mysql> select * from developerinfo where name = 'liujie' for update;
+--------+--------+----------+
| userID | name   | passWord |
+--------+--------+----------+
|      1 | liujie | 123456   |
+--------+--------+----------+
1 row in set

(3)查询非唯一索引字段来查询数据库使用行锁锁住多行

mysql的行锁是针对索引假的锁,不是针对记录,所以可能会出现锁住不同记录的场景

打开三个命令行窗口进行测试

命令行窗口1命令行窗口2命令行窗口3
mysql> set autocommit=0;
Query OK, 0 rows affected
mysql> select * from developerinfo where password = '123456
' for update;
+--------+--------+----------+
| userID | name   | passWord |
+-------- +--------+----------+
|      1 | liujie | 123456   |
|     3 | tong   | 123456   |
+--------+--------+---------- +
2 rows in set
mysql> set autocommit =0 ;
Query OK, 0 rows affected

mysql> select * from developerinfo where userid = '1' for update;

等待

mysql> set autocommit = 0;
Query OK, 0 rows affected
mysql> select * from developerinfo where userid = '2
' for update;
+--------+--------+----------+
| userID | name   | passWord |
+--------+--------+----------+
|      2 | yitong | 123     |
+--------+--------+----------+
1 row in set
commit;mysql> select * from developerinfo where userid = '1' for update;
+--------+--------+----------+
| userID | name   | passWord |
+--------+--------+----------+
|      1 | liujie | 123456   |
+--------+--------+----------+
1 row in set


以上是mysql行级锁的工作原理的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql行级锁的工作原理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql行级锁的实现原理是什么

MySQL行级锁的实现原理是通过两种方式来实现的:锁的粒度和锁的类型。锁的粒度:MySQL的行级锁是在InnoDB存储引擎中实现的,默认情况下使用的是Next-Key Lock,即在索引记录上的锁,包括行记录和索引记录,这样可以避免并发操
mysql行级锁的实现原理是什么
2024-04-09

深入理解MySQL的行级锁

目录☃️概述☃️行级锁介绍☃️行锁❄️❄️介绍❄️❄️演示☃️间隙锁&临键锁☃️概述锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中,除传统的计算资源(CPU、RAM、I/O)的争用以外,数据也是一种供许多用户共享的资源。
深入理解MySQL的行级锁
2024-09-10

深入理解MySQL中的行级锁

行级锁是MySQL中的一种并发控制机制,允许在同一时刻只允许一个事务访问数据库中的某一行记录,通过对特定行而非整个表进行锁定,可以提高并发性和性能。MySQL中有两种主要的行级锁类型:共享锁和排他锁。MySQL使用MVCC机制实现行级锁,并提供不同的隔离级别来指定行级锁的行为。使用注意事项包括死锁、锁升级、隔离级别影响和索引使用。最佳实践包括细粒度锁、适当的隔离级别、索引优化和监测锁争用。
深入理解MySQL中的行级锁
2024-04-02

mysql中Innodb 行锁实现原理

目录一、Innodb行锁的实现二、场景分析三、特殊场景一、Innodb行锁的实现【1】Innodb的行锁是通过给索引的索引项加锁来实现的【2】Innodb按照辅助索引进行数据操作时,辅助索引和主键索引都将锁定指定的索引项【3】通过索引
mysql中Innodb 行锁实现原理
2024-10-21

深入解析Golang中锁的工作原理

Golang中锁的工作原理深度剖析引言:在并发编程中,避免竞态条件(race condition)是至关重要的。为了实现线程安全,Golang提供了丰富的锁机制。本文将深入剖析Golang中锁的工作原理,并提供具体的代码示例。一、互斥锁(M
深入解析Golang中锁的工作原理
2023-12-28

java读写锁的工作原理是什么

读写锁是一种特殊的锁机制,允许多个线程同时读取共享资源,但只允许一个线程写入共享资源。读写锁的工作原理如下:当一个线程想要读取共享资源时,它必须先尝试获取读锁。如果没有写线程持有写锁,则读取线程可以获取读锁并进行读取操作。如果有其他线程已经
java读写锁的工作原理是什么
2024-04-03

MySQL的表级锁,行级锁,排它锁和共享锁

目录前言一、表级锁&行级锁二、排它锁&共享锁1. 测试不同事务之间排它锁和共享锁的兼容性2. 测试行锁加在索引项上三、串行化隔离级别测试前言如果我们和面试官聊到事务的问题,怎么回答呢?先说下事务是什么,因为我们业务是比较复杂的,不可能一
2022-07-14

MySQL的表级锁,行级锁,排它锁和共享锁是什么

这篇文章主要介绍“MySQL的表级锁,行级锁,排它锁和共享锁是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL的表级锁,行级锁,排它锁和共享锁是什么”文章能帮助大家解决问题。前言先说下事
2023-07-02

编程热搜

目录