文档章节

MySQL表锁_LOCK TABLES_UNLOCK TABLES

秋风醉了
 秋风醉了
发布于 2014/11/06 19:05
字数 950
阅读 2043
收藏 12

MySQL表锁_LOCK TABLES_UNLOCK TABLES

mysql5.6

参考文档:http://dev.mysql.com/doc/refman/5.6/en/lock-tables.html

锁表和解锁表的基本语法

LOCK TABLES    
    tbl_name [[AS] alias] lock_type
    [, tbl_name [[AS] alias] lock_type] ...
    
UNLOCK TABLES
lock_type:
    READ [LOCAL]
  | [LOW_PRIORITY] WRITE


MySQL锁表的目的

MySQL enables client sessions to acquire table locks explicitly(明白地,明确地) for the purpose of cooperating with other sessions for access to tables, or to prevent other sessions from modifying tables during periods when a session requires exclusive(单独的,排外的) access to them. A session can acquire or release locks only for itself. One session cannot acquire locks for another session or release locks held by another session.


LOCK TABLES

LOCK TABLES explicitly acquires table locks for the current client session. Table locks can be acquired for base tables or views. You must have the LOCK TABLES privilege, and the SELECT privilege for each object to be locked.

For view locking, LOCK TABLES adds all base tables used in the view to the set of tables to be locked and locks them automatically. If you lock a table explicitly with LOCK TABLES, any tables used in triggers are also locked implicitly.


UNLOCK TABLES

UNLOCK TABLES explicitly(明确的) releases any table locks held by the current session. LOCK TABLES implicitly(隐式的) releases any table locks held by the current session before acquiring new locks.

Another use for UNLOCK TABLES is to release the global read lock acquired with the FLUSH TABLES WITH READ LOCK statement, which enables you to lock all tables in all databases. 


WRITE LOCK 和 READ LOCK的作用

A table lock only protects against inappropriate(不恰当的,不合适的) reads or writes by other sessions. A session holding a WRITE lock can perform table-level operations such as DROP TABLE or TRUNCATE TABLE. For sessions holding a READ lock, DROP TABLE and TRUNCATE TABLE operations are not permitted. TRUNCATE TABLE operations are not transaction-safe, so an error occurs if the session attempts one during an active transaction or while holding a READ lock.


示例一:

该示例下的会话的事务都是自动提交的

会话一:

mysql> lock tables people read;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from people;
+-----------+------------+-----------+
| person_id | first_name | last_name |
+-----------+------------+-----------+
|         1 | 1111       | 1111      |
|         2 | 2222       | 2222      |
+-----------+------------+-----------+
2 rows in set (0.00 sec)

mysql>

在这个会话中,锁住表people,然后读取数据,此时在另外一个会话中,执行如下sql语句:

会话二

mysql> use local_database;
Database changed
mysql> lock tables people read;
Query OK, 0 rows affected (0.00 sec)

mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from people;
+-----------+------------+-----------+
| person_id | first_name | last_name |
+-----------+------------+-----------+
|         1 | 1111       | 1111      |
|         2 | 2222       | 2222      |
+-----------+------------+-----------+
2 rows in set (0.00 sec)

mysql> lock tables people write;

当给表people上read lock时,正常执行,也能正常unlock table,但是当给people表上write lock 时,发现当前会话被阻塞。。。

此时在会话一种执行如下sql:

mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

mysql>

好的,当执行完这句sql后,在会话二中的阻塞会消失。。

mysql> lock tables people write;
Query OK, 0 rows affected (50.40 sec)

mysql>

我们可以知道,一个会话中的read lock会阻塞另一个会话中的write lock,但不会阻塞read lock。。。

我们可以这样总结:

  • 表上的write lock会阻塞其他会话中write lock 和 read lock

  • 表上的read lock只会阻塞其他会话中write lock,而不会阻塞read lock

而行级锁也是同样的道理

我之前写的这篇博客也是同样的道理:http://my.oschina.net/xinxingegeya/blog/215417

继续探索:

在会话二中给表加了write lock,在会话二进行如下操作:

mysql> lock tables people write;
Query OK, 0 rows affected (50.40 sec)

mysql> select * from people;
+-----------+------------+-----------+
| person_id | first_name | last_name |
+-----------+------------+-----------+
|         1 | 1111       | 1111      |
|         2 | 2222       | 2222      |
+-----------+------------+-----------+
2 rows in set (0.00 sec)

mysql> delete from people where person_id = 2;
Query OK, 1 row affected (0.15 sec)

这些都是没问题的,删除表的操作就不演示了。。。。

当给表加了read lock 时,进行如下操作:

mysql> lock tables people read;
Query OK, 0 rows affected (0.00 sec)

mysql> delete from people where person_id = 2;
ERROR 1099 (HY000): Table 'people' was locked with a READ lock and can't be updated
mysql>

可以看到删除操作不允许,虽然数据库没有id=2的记录,但表被read lock了,所以不允许操作。。。

下面这些操作也不被允许:

mysql> drop table people;
ERROR 1099 (HY000): Table 'people' was locked with a READ lock and can't be updated
mysql> truncate people;
ERROR 1099 (HY000): Table 'people' was locked with a READ lock and can't be updated
mysql>

========END=========

© 著作权归作者所有

共有 人打赏支持
秋风醉了
粉丝 232
博文 574
码字总数 405033
作品 0
朝阳
程序员
Mysql的lock tables和unlock tables

http://blog.csdn.net/sunhuaquan/article/details/6202635 1 lock table 读锁定 对t1表加只读锁 本线程和其他线程只能读不能写 lock tables t1 read; unlock tables; 释放读锁 对t1表加只读...

harkdi
2016/02/18
24
0
mysql5.5 innodb的读锁定如何解锁

在mysql5.5的innodb中我给某张表加了一个共享读锁,命令如下: root:test>lock tables web_url read; 这个时候我对web_url的任何插入、更新、删除操作都会处于waiting for table level lock状...

pyruby
2013/12/03
2.1K
2
JAVA程序对MYSQL数据库加锁实验

以下实验仅在MySQL 5.0.45做的实验. 方法1:用mysql命令锁住表. 一、对于read lock 和 write lock官方说明: 1.如果一个线程获得一个表的READ锁定,该线程(和所有其它线程)只能从该表中读取...

mifans
2016/11/14
9
0
MySQL MVCC && 事务隔离级别 && 锁

MySQL MVCC && 事务隔离级别 && 锁 InnoDB多版本并发控制——MVCC http://my.oschina.net/xinxingegeya/blog/208821 MySQLS锁X锁read lockwrite lock http://my.oschina.net/xinxingegeya/bl......

秋风醉了
2014/07/30
0
0
Mysql(用MyISAM表结构)LOCK/UNLOCK TABLES妙用

用MyISAM 是为是速度,万一要atomic,我们可用LOCK/UNLOCK TABLES 解决。 但不为atomic,多表多个sql,用LOCK/UNLOCK TABLES 还可对MyISAM表,再提速(和缓存有关,我就不罗嗦了): ------...

jsyang888
2013/02/28
542
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

RabbitMQ在CentOS环境安装

1.废话不多说准备一台虚拟机,系统为centos,我这里使用的系统版本如下图所示:

凌晨一点
45分钟前
0
0
线程池相关

在java.util.concurrent包下,提供了一系列与线程池相关的类。 使用线程池的好处 降低资源消耗。通过重复利用已创建的线程降低线程创建和销毁造成的消耗; 提高响应速度。当任务到达时,任务...

edwardGe
47分钟前
0
0
学习大数据这三个关键技术是一定要掌握!

大数据时代全面来临,大数据、人工智能等技术引领科技创新潮流,获得国家政策大力支持,前景广阔。学习大数据技术的人自然是络绎不绝, 学习大数据虽然是一个趋势,但也要注意大数据培训课程...

董黎明
今天
0
0
jetbrains 上传代码到github

设置中找github 获取token 验证是否成功 测试git 生成key,一路回车即可 ssh-keygen -t rsa -C “youremail@example.com” 打开pub复制key,需要再次输入一次密码 验证是否成功,输入yes即可...

阿豪boy
今天
0
0
分布式服务框架(拾遗)

前言 现在的大部分工程都已经是基于分布式架构来处理。所以这里对分布式框架做一个简单的总结 常用的RPC框架 RPC框架原理 RPC(Remote Procedure Call,远程过程调用)一般用来实现部署在不同...

kukudeku
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部