mysql rowlock_MySQL锁篇

本文详细介绍了MySQL的锁机制,包括表级锁和行级锁。重点讲解了MyISAM和InnoDB存储引擎的锁特性,以及表锁(读锁和写锁)的使用方法和示例。此外,还探讨了元数据锁(MDL)的作用和行级锁(如记录锁、间隙锁和Next-Key锁)的实现与应用,以及死锁的概念和避免策略。
摘要由CSDN通过智能技术生成

1、MySQL锁介绍

2e75fc45d0eadce3bee46a91b6b2221f.png

MyISAM和MEMORY存储引擎采取的是表级锁

InnoDB既支持表级锁,又支持行级锁,但默认是行级锁。

表级锁:开销小,加锁快,不会死锁。锁定粒度大,发生锁冲突的概率最高,并发度最低。

行级锁:开销大,加锁慢,也会死锁。锁定粒度大,发生锁冲突的概率最高,并发度最低。

页面锁:开销和加锁时间,锁定粒度,介于表级行级锁中间,也会死锁。并发度一般。

表级锁适合以查询为主,只有少量按索引条件更新数据的应用。

行级锁适合有大量按索引条件并发,更新少量数据,同时又有并发查询的应用。

2、MySQL表级锁

2.1、表级锁介绍

由MySQL SQL layer层实现。

MySQL的表级锁有两种:

一种是表锁。一种是元数据锁(meta data lock,MDL)。

show status like 'table%;

aca0e932f6632dd8be71ffca3ac762bc.png

-- able_locks_immediate:产生表级锁定的次数;

-- able_locks_waited:出现表级锁定争用而发生等待的次数

2.2、表锁介绍

2.2.1 表现模式形式:

表共享读锁(Table Read Lock)

表独占写锁(Table Write Lock)

2.2.2 手动增加表锁

lock table 表名称 read(write),表名称2 read(write);

2.2.3 查看表锁情况

show open tables;

2.2.4 删除表锁

unlock table;

2.3 表锁演示

2.3.1环境准备

-- 新建表

CREATE TABLE mylock (

id int(11) NOT NULL AUTO_INCREMENT,

NAME varchar(20) DEFAULT NULL,

PRIMARY KEY (id));

INSERT INTO mylock (id,NAME) VALUES (1, 'a');

INSERT INTO mylock (id,NAME) VALUES (2, 'b');

INSERT INTO mylock (id,NAME) VALUES (3, 'c');

INSERT INT

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:MySQL 排查锁表常用Sql锁信息查询是否被锁的表查询innodb事务获取的锁 查询会话当前会话列表基于IP过滤基于数据库过滤会话详情查询会话执行过的sql 杀死会话杀死指定会话生成杀死某一IP下会话SQL。引用\[2\]:MySQL查看锁的sql 查看数据库状态 # 会显示加锁的信息等等 show engine innodb status; 查看正在执行的线程信息 show full processlist; 查看正在锁的表 show open tables where in_use > 0; show open tables; 查看锁的类型、状态 show status like '%lock%'; 5.0后,增加了3个关于锁的表 MySQL5.7版本 INFORMATION_SCHEMA.innodb_trx 当前运行的所有事务INFORMATION_SCHEMA.innodb_locks 当前出现的锁INFORMATION_SCHEMA.innodb_lock_waits 锁等待的对应关系 MySQL8.0版本。引用\[3\]:8.0后,performance_schema.data_locks代替了INFORMATION_SCHEMA.innodb_locks ,performance_schema.data_lock_waits代替了INFORMATION_SCHEMA.innodb_lock_waits 查看正在锁的事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 5.7 SELECT * FROM performance_schema.data_locks; -- 8.0 查看等待锁的事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; -- 5.7 SELECT * FROM performance_schema.data_lock_waits; -- 8.0 查看行锁情况 show status like 'InnoDB_row_lock%'; 查看表锁情况 show status like 'table%'; 开启锁监控。 问题: mysql查询锁表的sql 回答: 要查询MySQL中的锁表信息,可以使用以下SQL语句: - 查看数据库状态,包括加锁的信息等等: `show engine innodb status;` - 查看正在执行的线程信息: `show full processlist;` - 查看正在锁的表: `show open tables where in_use > 0;` 或者 `show open tables;` - 查看锁的类型和状态: `show status like '%lock%';` - MySQL5.7版本及以上,可以使用以下表来查看锁的信息: - 当前运行的所有事务: `SELECT * FROM INFORMATION_SCHEMA.innodb_trx;` - 当前出现的锁: `SELECT * FROM INFORMATION_SCHEMA.innodb_locks;` - 锁等待的对应关系: `SELECT * FROM INFORMATION_SCHEMA.innodb_lock_waits;` - MySQL8.0版本及以上,可以使用以下表来查看锁的信息: - 当前运行的所有事务: `SELECT * FROM performance_schema.data_locks;` - 锁等待的对应关系: `SELECT * FROM performance_schema.data_lock_waits;` - 查看行锁情况: `show status like 'InnoDB_row_lock%';` - 查看表锁情况: `show status like 'table%';` - 开启锁监控: 可以根据具体需求选择合适的监控工具或配置来实现锁的监控。 #### 引用[.reference_title] - *1* [MySQL 排查锁表常用SQL](https://blog.csdn.net/qq1620657419/article/details/124846298)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [MySQL查看锁的sql](https://blog.csdn.net/blood_Z/article/details/128779095)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值