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

MySQL查看锁的实现代码

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

MySQL查看锁的实现代码

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版本

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%';

开启锁监控

开启监控后,可以看到锁的具体信息以及加锁顺序等,更容易分析死锁。

方式一:创建监控表,监控某个数据库

开启:

CREATE TABLE innodb_lock_monitor (a INT) ENGINE=INNODB;

关闭:

DROP TABLE innodb_lock_monitor;

注意:在未拥有设置全局属性权限下也可以开启该功能。

方式二,开启全局监控

开启:

set GLOBAL innodb_status_output=ON;
set GLOBAL innodb_status_output_locks=ON;

关闭:

set GLOBAL innodb_status_output=OFF;
set GLOBAL innodb_status_output_locks=OFF;

查看数据库状态

show engine innodb status \G;

其他监控

标准监控(Standard InnoDB Monitor):监视活动事务持有的表锁、行锁;事务锁等待;线程信号量等待;文件IO请求;buffer pool统计信息;InnoDB主线程purge和change buffer merge活动。

# 方式一
CREATE TABLE innodb_monitor (a INT) ENGINE=INNODB;
DROP TABLE innodb_monitor;
# 方式二
set GLOBAL innodb_status_output=ON;
set GLOBAL innodb_status_output=OFF;

锁监控(InnoDB Lock Monitor):提供额外的锁信息。

# 方式一
CREATE TABLE innodb_lock_monitor (a INT) ENGINE=INNODB;
DROP TABLE innodb_lock_monitor;
# 方式二
set GLOBAL innodb_status_output=ON;
set GLOBAL innodb_status_output_locks=ON;
set GLOBAL innodb_status_output=OFF;
set GLOBAL innodb_status_output_locks=OFF;

表空间监控(InnoDB Tablespace Monitor):显示共享表空间中的文件段以及表空间数据结构配置验证。

CREATE TABLE innodb_tablespace_monitor (a INT) ENGINE=INNODB;
DROP TABLE innodb_tablespace_monitor;

表监控(InnoDB Table Monitor):显示内部数据字典的内容。

CREATE TABLE innodb_tablespace_monitor (a INT) ENGINE=INNODB;
DROP TABLE innodb_tablespace_monitor;

到此这篇关于MySQL查看锁的实现代码的文章就介绍到这了,更多相关MySQL查看锁内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

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

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

MySQL查看锁的实现代码

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

下载Word文档

猜你喜欢

MySQL查看锁的实现代码

目录mysql查看锁的sql开启锁监控其他监控MySQL查看锁的sql查看数据库状态# 会显示加锁的信息等等show engine innodb status; 查看正在执行的线程信息show full processlist;查
2023-02-05

MySQL查看锁的代码怎么写

本文小编为大家详细介绍“MySQL查看锁的代码怎么写”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL查看锁的代码怎么写”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。MySQL查看锁的sql查看数据库状态
2023-07-05

MySQL查看锁表的实现步骤

本文介绍了5种详细步骤,帮助您查看MySQL中的锁表:查询INFORMATION_SCHEMA.INNODB_LOCKS表以查看当前持有的InnoDB锁。运行SHOWPROCESSLIST查询并查看Info列以查找持有锁的线程。使用INFORMATION_SCHEMA.INNODB_LOCK_WAITS表查看正在等待锁的事务。运行SHOWINNODBSTATUS查询以查看有关InnoDB状态的信息,包括活动和等待锁的事务。使用MySQL性能模式启用高级锁和死锁监控。
MySQL查看锁表的实现步骤
2024-04-02

MySQL查看锁的sql

MySQL查看锁的sql 查看数据库状态 # 会显示加锁的信息等等show engine innodb status; 查看正在执行的线程信息 show full processlist; 查看正在锁的表 show open table
2023-08-18

基于mysql乐观锁实现秒杀的示例代码

目录说明具体实现代码实现说明如果你的项目流量非常小,完全不用担心有并发的购买请求,那么做这样一个系统意义不大。但如果你的系统要像12306那样,接受高并发访问和下单的考验,那么你就需要一套完整的流程保护措施,来保证你系统在用户流量高峰期不
2022-07-01

mysql查询锁表的实现方法

目录1.查看表是否被锁2.查看表被锁状态和结束死锁步骤3.mysql查询锁表指令速查今天在做数据更新的时候,发现表中数据量不大,但是更新语句执行很久都没成功,经过查询后发现是表锁死导致的,本文记录一下锁表解决步骤:1.查看js表是否被锁
mysql查询锁表的实现方法
2024-09-04

MySQL实现查询分位值的示例代码

目录背景业务背景思考效果参考背景分位值的概念分位值:分位值(Quartile)是一种用于描述数据分布的统计概念,在统计学和数据分析中经常被用到。一般情况下,分位值分成四个等份,分别为第一分位数(Q1)、第二分位数(Q2)(也就是中位数)
2023-04-24

android网络图片查看器简单实现代码

本文实例为大家分享了android网络图片查看器的具体代码,供大家参考,具体内容如下效果图:1.输入一个图片url2.转换成bitmap位图3.展示到ImageView上xml:2023-05-31

mysql查看死锁的方法是什么

要查看MySQL中的死锁,可以使用以下方法:使用SHOW ENGINE INNODB STATUS命令来查看当前的死锁情况。该命令会返回一个包含详细信息的InnoDB状态报告,其中包含了当前的死锁信息。使用SELECT FROM INF
mysql查看死锁的方法是什么
2024-04-09

MySQL查看所有用户的实现

目录列出所有用户在mysql中查看用户的详细信息MySQL中如何查看当前用户列出所有用户如下语句可以查询所有用户SELECT user FROM 数据库的名字.user;在这条语句中,我们从mysql数据库的用户表中查询用户的数据.在
2023-03-08

编程热搜

目录