文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL 5.5中LOCK TABLES和UNLOCK TABLES语句有哪些

2024-04-02 19:55

关注

这篇文章主要介绍了MySQL 5.5中LOCK TABLES和UNLOCK TABLES语句有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

LOCK TABLES 可以为当前客户端会话的表加锁。表锁可以加到表或视图中。你需要具有LOCK TABLES权限和对表的查询权限。当执行LOCK TABLES语句时,表中的触发器也会被锁住。
表锁可以防止其他会话对表的读或写。持有写锁的会话可以执行DROP TABLE或TRUNCATE TABLE语句,持有读锁的会话,不允许执行DROP TABLE或TRUNCATE TABLE语句。

读锁(READ [LOCAL] lock)

持有锁的会话可以读取表,但是不能执行写入操作。

多个会话可以在同一时间获取相同表的读锁。

其他没有获取读锁的会话可以读取表中的内容。

LOCAL标识符可以使其他会话执行并发的INSERT语句。对于InnoDB表,READ LOCAL和READ具有同样的效果。

例子一:
--会话①
mysql> lock table t10 read;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from t10;
+------+---------------------+
| name | email               |
+------+---------------------+
| Neo  | feelpurple@163.com  |
| fire | real_neo@163.com    |
| xxx  | real_xiaomm@163.com |
+------+---------------------+
3 rows in set (0.00 sec)

--会话②,可以执行查询语句,对表的DML、DDL操作会处于阻塞状态,直到会话①表锁被释放
mysql> select * from t10;
+------+---------------------+
| name | email               |
+------+---------------------+
| Neo  | feelpurple@163.com  |
| fire | real_neo@163.com    |
| xxx  | real_xiaomm@163.com |
+------+---------------------+
3 rows in set (0.00 sec)

mysql> insert into t10 values('Jason','real_xiaoyu@163.com');

--会话①
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

--会话②
mysql> insert into t10 values('Jason','real_xiaoyu@163.com');
Query OK, 1 row affected (2 min 7.82 sec)

当一个会话获取表锁后,这个会话只能访问被锁的这张表,直到表锁被释放为止。

例子二:
--会话①
mysql> lock table t10 read;
Query OK, 0 rows affected (0.00 sec)

mysql> select count(*) from t10;
+----------+
| count(*) |
+----------+
|        3 |
+----------+
1 row in set (0.00 sec)

mysql> select count(*) from t11;
ERROR 1100 (HY000): Table 't11' was not locked with LOCK TABLES
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

mysql> select count(*) from t10;
+----------+
| count(*) |
+----------+
|        3 |
+----------+
1 row in set (0.00 sec)

mysql> select count(*) from t11;
+----------+
| count(*) |
+----------+
|        1 |
+----------+
1 row in set (0.00 sec)

写锁(WRITE lock)

持有锁的会话可以对表执行读写操作。

只有获取锁的会话才能访问表。只有当锁释放掉,其他的会话才可以访问表。

当表被加上写锁的时候,其他对这张表的锁定请求会被阻塞。

--例子三:

--会话①
mysql> lock table t10 write;
Query OK, 0 rows affected (0.00 sec)

mysql> select count(*) from t10;
+----------+
| count(*) |
+----------+
|        4 |
+----------+
1 row in set (0.00 sec)

--会话②,对表的查询、DML、DDL操作都会处于阻塞状态,直到会话①表锁被释放
mysql> select * from t10;

--会话①
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)

--会话②
mysql> select * from t10;
+---------------------+
| email               |
+---------------------+
| feelpurple@163.com  |
| real_neo@163.com    |
| real_xiaomm@163.com |
| real_xiaoyu@163.com |
+---------------------+
4 rows in set (1 min 35.10 sec)

--会话①
mysql> lock table t10 write;
Query OK, 0 rows affected (0.00 sec)

--会话②的DML操作会处于阻塞状态
mysql> insert into t10 values('real_xiaolan@163.com');

--会话①
mysql> unlock tables;
Query OK, 0 rows affected (0.01 sec)

--会话②的DML操作成功
mysql> insert into t10 values('real_xiaolan@163.com');
Query OK, 1 row affected (35.04 sec)

--会话①,此时如果会话②不提交或回滚事务,则会话①再次执行LOCK TABLE语句会阻塞
mysql> lock table t10 write;

--会话②
mysql> rollback;
Query OK, 0 rows affected (0.00 sec)

--会话①
mysql> lock table t10 write;
Query OK, 0 rows affected (24.75 sec)

UNLOCK TABLES 会释放当前会话的表锁,也可以释放FLUSH TABLES WITH READ LOCK(这个命令会给MySQL中所有的数据库加锁)语句所加的全局只读锁。

感谢你能够认真阅读完这篇文章,希望小编分享的“MySQL 5.5中LOCK TABLES和UNLOCK TABLES语句有哪些”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯