mysql 数据库表被锁住了_MYSQL数据库MYSQL 解锁与锁表介绍

《MYSQL数据库MYSQL 解锁与锁表介绍》要点:

本文介绍了MYSQL数据库MYSQL 解锁与锁表介绍,希望对您有用。如果有疑问,可以联系我们。

MYSQL学习MySQL锁概述

相对其他数据库而言,MySQL的锁机制比拟简单,其最显著的特点是不同的存储引擎支持不同的锁机制.比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁.

MySQL这3种锁的特性可大致归纳如下.

开销、加锁速度、死锁、粒度、并发性能

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

l         行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高.

l         页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般.

MyISAM表锁

MYSQL学习MyISAM存储引擎只支持表锁,这也是MySQL开始几个版本中唯一支持的锁类型.随着应用对事务完整性和并发性要求的赓续提高,MySQL才开始开发基于事务的存储引擎,后来慢慢出现了支持页锁的BDB存储引擎和支持行锁的InnoDB存储引擎(实际 InnoDB是单独的一个公司,现在已经被Oracle公司收购).但是MyISAM的表锁依然是使用最为广泛的锁类型.本节将详细介绍MyISAM表锁的使用.

查询表级锁争用情况

MYSQL学习可以通过检查table_locks_waited和table_locks_immediate状态变量来分析系统上的表锁定争夺:

mysql> show status like 'table%';

+-----------------------+-------+

| Variable_name         | Value |

+-----------------------+-------+

| Table_locks_immediate | 2979  |

| Table_locks_waited    | 0     |

+-----------------------+-------+

2 rows in set (0.00 sec))

如果Table_locks_waited的值比拟高,则说明存在着较严重的表级锁争用情况.

获取InnoDB行锁争用情况

MYSQL学习可以通过检查InnoDB_row_lock状态变量来分析系统上的行锁的争夺情况:

mysql> show status like 'innodb_row_lock%';

+-------------------------------+-------+

| Variable_name                 | Value |

+-------------------------------+-------+

| InnoDB_row_lock_current_waits | 0     |

| InnoDB_row_lock_time          | 0     |

| InnoDB_row_lock_time_avg      | 0     |

| InnoDB_row_lock_time_max      | 0     |

| InnoDB_row_lock_waits         | 0     |

+-------------------------------+-------+

5 rows in set (0.01 sec)

如果发现锁争用比拟严重,如InnoDB_row_lock_waits和InnoDB_row_lock_time_avg的值比拟高,还可以通过

MYSQL进修解锁

MYSQL进修第一种

MYSQL进修show processlist;

MYSQL学习找到锁过程,kill id ;

MYSQL进修第二种

MYSQL进修mysql>UNLOCK TABLES;

MYSQL进修锁表

MYSQL学习锁定数据表,避免在备份进程中,表被更新

MYSQL进修mysql>LOCK TABLES tbl_name READ;

MYSQL进修为表增加一个写锁定:

MYSQL进修mysql>LOCK TABLES tbl_name WRITE;

欢迎参与《MYSQL数据库MYSQL 解锁与锁表介绍》讨论,分享您的想法,编程之家PHP学院为您提供专业教程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值