MySQL服务器的内部锁定

数据库 MySQL
MySQL服务器的内部锁定可以避免客户机的请求相互干扰,下面就为您详细介绍MySQL服务器内部锁定的语法,供您参考学习。

内部锁定是MySQL服务器锁定的两种方式之一,下面就对MySQL服务器的内部锁定作详尽的介绍,如果您对MySQL服务器锁定方面感兴趣的话,不妨一看。

内部锁定

内部锁定可以避免客户机的请求相互干扰——例如,避免客户机的SELECT查询被另一个客户机的UPDATE查询所干扰。也可以利用内部锁定机制防止MySQL服务器在利用myisamchk或isamchk检查或修复表时对表的访问。

语法:

锁定表:LOCK TABLES tbl_name {READ | WRITE},[ tbl_name {READ | WRITE},…]

解锁表:UNLOCK TABLES

LOCK TABLES为当前线程锁定表。UNLOCK TABLES释放被当前线程持有的任何锁。当线程发出另外一个LOCK TABLES时,或当MySQL服务器的连接被关闭时,当前线程锁定的所有表自动被解锁。

如果一个线程获得在一个表上的一个READ锁,该线程(和所有其他线程)只能从表中读。如果一个线程获得一个表上的一个WRITE锁,那么只有持锁的线程READ或WRITE表,其他线程被阻止。

每个线程等待(没有超时)直到它获得它请求的所有锁。

WRITE锁通常比READ锁有更高的优先级,以确保更改尽快被处理。这意味着,如果一个线程获得READ锁,并且然后另外一个线程请求一个WRITE锁, 随后的READ锁请求将等待直到WRITE线程得到了锁并且释放了它。

显然对于检查,你只需要获得读锁。再者钟情跨下,只能读取表,但不能修改它,因此他也允许其它客户机读取表。对于修复,你必须获得些所以防止任何客户机在你对表进行操作时修改它。

 

 

【编辑推荐】

MySQL单表大小的限制

根据Mysql表备份

MySQL Show语句用法介绍

MySQL服务器的启动与停止

查看Mysql表结构的命令

责任编辑:段燃 来源: 互联网
相关推荐

2009-11-23 17:23:59

DNS服务器内部建立

2010-01-26 16:43:30

AMD CEO

2019-04-26 10:57:26

无服务器应用程序HTTP

2011-07-05 10:48:54

2009-09-25 10:13:15

2010-04-27 10:31:54

龙芯刀片服务器

2018-08-13 09:09:35

Nginx服务器内部

2010-10-14 15:50:33

MySQL服务器

2011-03-23 10:17:26

2014-12-30 09:35:21

数据中心

2010-05-19 15:00:37

IIS服务器

2009-02-27 13:33:00

2017-09-14 08:43:05

2011-07-25 15:05:05

英特尔服务器云计算

2010-05-20 13:22:32

2010-10-11 17:23:47

mysql建主从服务器

2010-05-19 17:44:09

2010-10-11 17:16:13

mysql服务器

2011-03-15 16:19:15

MySQL服务器访问

2010-05-21 11:50:54

IIS服务器
点赞
收藏

51CTO技术栈公众号