文档章节

MySQL表锁_LOCK TABLES_UNLOCK TABLES

秋风醉了
 秋风醉了
发布于 2014/11/06 19:05
字数 950
阅读 2199
收藏 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=========

© 著作权归作者所有

秋风醉了
粉丝 250
博文 536
码字总数 408434
作品 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
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
mydumper 备份原理和使用方法(备份mysql)

一:我的使用环境:CentOS6.5 + Mysql5.7 MySQL备份工具比较: 1、mysqldump:属于逻辑备份,会存在锁表,但考虑到数据量比较大,锁表的时间会比较长,业务不允许,pass掉; 2、xtrabackup:...

洋哥6
2016/09/08
78
0
Mysql(用MyISAM表结构)LOCK/UNLOCK TABLES妙用

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

jsyang888
2013/02/28
550
0

没有更多内容

加载失败,请刷新页面

加载更多

二进制位操作

单片机,或者一些模块的设置操作,都是由一个字节数据来完成,每位各有定义。就需进行位操作来组合需要的数字结果。 以JavaScript为例,编写位操作。 我们期望得到这样一个二进制数:0101101...

format
32分钟前
3
0
聊聊中国的通信行业:从“七国八制”到“中华”脊梁

本期文章和大家一起来聊一聊我曾经从事过的通信行业吧。最近各方面信息的泛滥,包括和华为的同学聊天,自己确实也感慨颇多。想想我自己本科主修通信工程,研究生再修信息与通信工程,从本科开...

CodeSheep
今天
6
0
MDK:ARM M451M:exceed the range of code meory, continue to erase or not?

问题: 代码空间超限 几天前就遇到:exceed the range of code meory, continue to erase or not? 如下所示: 解决过程 开始以为中MDK软件的128KB限制,如是就不能生成HEX文件,应该链接时有提...

SamXIAO
今天
1
1
OSChina 周六乱弹 —— 因违反《中华人民共和国治安管理处罚法》第四十四条之规定

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @xiaoshiyue :#今日歌曲推荐# 惊艳分享谷微的单曲《安守本份》(@网易云音乐) 《安守本份》- 谷微 手机党少年们想听歌,请使劲儿戳(这里) ...

小小编辑
今天
574
12
Angular 英雄编辑器

应用程序现在有了基本的标题。 接下来你要创建一个新的组件来显示英雄信息并且把这个组件放到应用程序的外壳里去。 创建英雄组件 使用 Angular CLI 创建一个名为 heroes 的新组件。 ng gener...

honeymoose
今天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部