MySql数据库锁处理

本文详细介绍了MySQL的三种锁级别:页级、表级和行级,以及两种基本锁类型:排它锁(X锁)和共享锁(S锁)。通过实例展示了如何使用BEGIN和COMMIT进行事务管理,并讲解了如何查看和处理数据库中的锁定和死锁情况,包括使用KILL命令结束线程、检查死锁日志以及调整锁等待时间。此外,还提供了模拟死锁的场景,帮助理解死锁的产生原因。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • MySQL有三种锁的级别:页级、表级、行级
  • 两种基本的锁类型
    • 排它锁(Exclusive Locks,即X锁)
      当数据对象被加上排它锁时,其他的事务不能对它读取和修改。
    • 共享锁(Share Locks,即S锁)。
      加了共享锁的数据对象可以被其他事务读取,但不能修改。

数据库操作

  • 显示哪些线程正在运行
show full PROCESSLIST
  • 查询当前的事务
select * from information_schema.innodb_trx;
  • KILL trx_mysql_thread_id 杀死线程 若存在死锁 杀死死锁线程
KILL 8437;
  • 查看当前锁定的事务
-- 5.7
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

-- 8.0
select * from performance_schema.data_locks;
  • 查看当前等锁的事务
-- 5.7
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

-- 8.0
select * from performance_schema.data_lock_waits;
  • 查看死锁日志
SHOW ENGINE INNODB STATUS;

查看死锁日志可以知道死锁成因,死锁发生的位置,以及数据库做出的处理
死锁日志

  • 查看锁等待时间 (默认50s)
show variables like 'innodb_lock_wait_timeout'; 
  • 死锁检测开启状态
show variables like 'innodb_deadlock_detect';
数据库模拟锁

利用 BEGINCOMMIT 模拟一个事务的生命周期,不COMMIT即事务进行中

  • 手动锁定一行数据
BEGIN;
SELECT * FROM biz_plank_sample WHERE bar_code = '10003153270245' FOR UPDATE;
-- COMMIT;

commit 即不提交, FOR UPDATE会加一个行级锁

  • 模拟死锁 Deadlock
    死锁一般会报错:Deadlock found when trying to get lock; try restarting transaction

死锁是指两个或两个以上事务在执行过程中因争抢锁资源而造成的互相等待的现象。

客户端1:

BEGIN;
SELECT * FROM biz_plank_sample WHERE bar_code = '10003153270245' FOR UPDATE;
SELECT * FROM biz_plank_sample WHERE bar_code = '12565452535658' FOR UPDATE;
COMMIT;

客户端2:

BEGIN;
SELECT * FROM biz_plank_sample WHERE bar_code = '12565452535658' FOR UPDATE;
SELECT * FROM biz_plank_sample WHERE bar_code = '10003153270245' FOR UPDATE;
COMMIT;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值