开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1668|回复: 2
收起左侧

[Mysql] MySQL锁的用法之表级锁

[复制链接]

结帖率:61% (35/57)
发表于 2013-1-7 14:45:02 | 显示全部楼层 |阅读模式   海南省乐东黎族自治县
锁机制是数据库有别于文件系统的一个重要的特点,也是用来管理并发访问的一个有效的方式。MySQL 的锁分为表级锁、页级锁与行级锁。表级锁是MySQL中粒度最大的一种锁,它实现简单,资源消耗较少,被大部分MySQL引擎支持。最常使用的 MYISAM与INNODB都支持表级

锁机制是数据库有别于文件系统的一个重要的特点,也是用来管理并发访问的一个有效的方式。MySQL 的锁分为表级锁、页级锁与行级锁。表级锁是MySQL中粒度最大的一种锁,它实现简单,资源消耗较少,被大部分MySQL引擎支持。最常使用的 MYISAM与INNODB都支持表级锁定。
  表级锁定分为两类,读锁与写锁。读锁是预期将对数据表进行读取操作,锁定期间保证表不能被修改。写锁是预期会对数据表更新操作,锁定期间保证表不能被其他线程更新或读取。
  读锁:
  用法:LOCK TABLE table_name [ AS alias_name ] READ
  指定数据表,LOCK类型为READ即可,AS别名是可选参数,如果指定别名,使用时也要指定别名才可
  申请读锁前提:当前没有线程对该数据表使用写锁,否则申请会阻塞。
  操作限制:其他线程可以对锁定表使用读锁;其他线程不可以对锁定表使用写锁
  对于使用读锁的MySQL线程,由于读锁不允许任何线程对锁定表进行修改,在释放锁资源前,该线程对表操作只能进行读操作,写操作时会提示非法 操作。而对于其他没使用锁的MySQL线程,对锁定表进行读操作可以正常进行,但是进行写操作时,线程会等待读锁的释放,当锁定表的所有读锁都释放时,线 程才会响应写操作。
  写锁:
  用法:LOCK TABLE table_name [AS alias_name] [ LOW_PRIORITY ] WRITE
  别名用法与读锁一样,写锁增加了指定优先级的功能,加入LOW_PRIORITY可以指定写锁为低优先级。
  申请写锁前提:当没有线程对该数据表使用写锁与读锁,否则申请回阻塞。
  操作限制:其他MySQL线程不可以对锁表使用写锁、读锁
  对于使用写锁的MySQL线程,其可以对锁定表进行读写操作。但是对于其他线程,对指定表读写操作都是非法的,需要等待直到写锁释放。
  锁分配优先级:
  对于锁分配的优先级,是: LOW_PRIORITY WRITE < READ < WRITE
  1、当多个线程申请锁,会优先分配给WRITE锁,不存在WRITE锁时,才分配READ锁,LOW_PRIORITY WRITE需要等到WRITE锁与READ都释放后,才有机会分配到资源。
  2、对于相同优先级的锁申请,分配原则为谁先申请,谁先分配。
  注意事项:
  1、不能操作(查询或更新)没有被锁定的表。
  例如当只申请table1的读锁,SQL语句中包含对table2的操作是非法的。例如:
  mysql> LOCK TABLE test READ;
  Query OK, 0 rows affected (0.00 sec)
  mysql> SELECT * FROM test_myisam;
  ERROR 1100 (HY000): Table 'test_myisam' was not locked with LOCK TABLES
  2、不能在一个SQL中使用两次表(除非使用别名)
  当SQL语句中多次使用一张表时,系统会报错。例如:
  mysql> LOCK TABLE test READ;
  Query OK, 0 rows affected (0.00 sec)
  mysql> SELECT * FROM test WHERE id IN (SELECT id FROM test );
  ERROR 1100 (HY000): Table 'test' was not locked with LOCK TABLES
  解决这个问题的方法是使用别名,如果多次使用到一个表,需要声明多个别名。
  mysql> LOCK TABLE test AS t1 READ, test AS t2 READ;
  Query OK, 0 rows affected (0.00 sec)
  mysql>  SELECT * FROM test AS t1 WHERE id IN (SELECT id FROM test AS t2);
  +----+-----------+
  | id | content   |
  +----+-----------+
  |  1 | tt_1      |
  |  3 | new_3     |
  |  4 | new_4     |
  |  5 | content_5 |
  +----+-----------+
  4 rows in set (0.00 sec)
  3、申请锁时使用别名,使用锁定表时必须加上别名。

签到天数: 7 天

发表于 2021-10-23 17:21:20 | 显示全部楼层   重庆市重庆市

回帖奖励 +1 枚 精币

111111111111111111111
回复 支持 反对

使用道具 举报

结帖率:100% (11/11)
发表于 2013-1-7 14:48:54 | 显示全部楼层   河北省衡水市

回帖奖励 +1 枚 精币

不感兴趣 只为精币而来
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表