1. 默认情况下 ,表锁和行锁都是自动获得的,不需要额外命令。
2. 某些情况下,用户需要明确地进行锁表或者进行事务的控制,以便确保整个事务的完整性。
3. LOCK TABLES 可以锁定用于当前线程的表。如果表被其他线程锁定,则当前线程会等待,直到可以获取所有锁定为止。
4. UNLOCK TABLES 可以释放当前线程获得的任何锁定。
注 a. 当前线程执行另一个LOCK TABLES 时,或当与服务器的联接被关闭时,所有当前线程锁定的表被隐含地解锁
锁表语法:
LOCK TABLES
tbl_name [AS alias] {READ [LOCAL] \ [ LOW_PRIORITY ] WRITE] }
[,tbl_name [ AS alias ] { READ [LOCAL] \ [ LOW_PRIORITY WRITE]}]
UNLOCK TABLES
例句:
锁表: lock table film_text read;
释放锁: unlock tables;