데이터 베이스 MySQL 튜토리얼 MySQL InnoDB存储引擎锁机制实验

MySQL InnoDB存储引擎锁机制实验

Jun 07, 2016 pm 05:28 PM
mysql innodb MySQL의 잠금

之前的文章提到MySQL的InnoDB存储引擎使用的是行级锁,并且默认的事务隔离级别为可重复读,而不同于Oracle默认的事务隔离级别提交

之前的文章提到MySQL的InnoDB存储引擎使用的是行级锁,并且默认的事务隔离级别为可重复读,而不同于Oracle默认的事务隔离级别提交读。那么MySQL的InnoDB存储引擎的锁机制的具体表现是怎样的呢?

相关阅读:MySQL数据库锁机制

实验如下:
 
首先建立一张测试使用的表:
 
CREATE TABLE`test_innodb_lock` (
 
  `a` int(11) DEFAULT NULL,
 
  `b` varchar(16) DEFAULT NULL,
 
  KEY `test_innodb_lock_a_IDX` (`a`)
 
) ENGINE=InnoDB
 
        然后再往这张表里插入一些数据,以备使用,最终表数据如下:
 
+------+------+
 
| a  | b    |
 
+------+------+
 
|  1 | a    |
 
|  1 | x    |
 
|  1 | y    |
 
|  2 | b    |
 
|  2 | w    |
 
|  2 | z    |
 
|  3 | c    |
 
|  4 | d    |
 
|  5 | e    |
 
|  8 | ff  |
 
|  8 | f    |
 
|  10 | g    |
 
+------+------+
 
 
 
首先我们来看看行级锁的情况:
 
实验一:
 
打开两个MySQL客户端,
 
在客户端1执行:
 
mysql> set autocommit = 0;
 
Query OK, 0 rows affected (0.00 sec)
 
修改客户端1的事务提交方式为手动提交;
 
 
 
在客户端2执行:
 
mysql> set autocommit = 0;
 
Query OK, 0 rows affected (0.00 sec)
 
同样修改客户端2的事务提交方式为手动提交;
 
 
 
在客户端1执行:
 
mysql> update test_innodb_lock set b ='xxx' where  a = 1 and b = 'y';
 
Query OK, 1 row affected (0.00 sec)
 
Rows matched: 1  Changed: 1 Warnings: 0
 
同时使用索引字段a和非索引字段b更新一条数据;
 
 
 
在客户端2执行:
 
mysql> update test_innodb_lock set b ='xxx' where a=1 and b = 'x';
 
同时使用索引字段a(并且索引值同客户端1的值相同)和非索引字段更新另外一条数据;
 
结果发现客户端2的update语句被阻塞,,需要客户端1提交或回滚才能继续执行。说明,虽然两个事务最终更新的数据不是同一条数据,但然后可能被锁定,这是因为两条SQL语句都使用了相同的索引值(a=1),行级锁上升为页级锁。
 
实验二:
 
在客户端1执行:
 
mysql> rollback;
 
Query OK, 0 rows affected (0.00 sec)
 
回滚实验一的操作;
 
 
 
在客户端2执行:
 
mysql> rollback;
 
Query OK, 0 rows affected (0.00 sec)
 
回滚实验一的操作;
 
 
 
在客户端1执行:
 
mysql> update test_innodb_lock set b ='xxx' where  a = 1 and b = 'a';
 
Query OK, 1 row affected (0.00 sec)
 
Rows matched: 1  Changed: 1 Warnings: 0
 
同时使用索引字段a和非索引字段b更新一条数据;
 
 
 
在客户端2执行:
 
mysql> update test_innodb_lock set b ='xxx' where a=2 and b = 'b';
 
Query OK, 1 row affected (0.00 sec)
 
Rows matched: 1  Changed: 1 Warnings: 0
 
同时使用索引字段a(索引值不同于客户端1SQL语句的索引值)和非索引字段b更新一条数据;
 
更新顺利进行,执行并没有被阻塞;
 
说明,同是根据索引和非索引字段进行更新数据,当两个事务的SQL语句中的索引条件值不一样时,更新仍然能够顺利进行。

linux

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker에서 MySQL 메모리 사용을 줄입니다 Docker에서 MySQL 메모리 사용을 줄입니다 Mar 04, 2025 pm 03:52 PM

Docker에서 MySQL 메모리 사용을 줄입니다

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Mar 19, 2025 pm 03:51 PM

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. Mar 04, 2025 pm 04:01 PM

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

sqlite 란 무엇입니까? 포괄적 인 개요 sqlite 란 무엇입니까? 포괄적 인 개요 Mar 04, 2025 pm 03:55 PM

sqlite 란 무엇입니까? 포괄적 인 개요

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Mar 04, 2025 pm 03:54 PM

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 Mar 04, 2025 pm 03:49 PM

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? 인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? Mar 21, 2025 pm 06:28 PM

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? Mar 18, 2025 pm 12:01 PM

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까?

See all articles