MyISAM 类型表的表级锁定:
1.读锁定不会阻塞其他进程的读。
2.读锁定会阻塞所有线程的写入(insert and update and delete),包括自己所在的进程。
3.如果锁定时加local 参数,则其他线程的inser 不会阻塞,并且在读锁定期间,如其他线程有insert写入数据,此时无法即时看到。但会阻塞update,delete 操作
---------------------------------------------------------------
Lock tables orders read local, order_detail read local;
Select sum(total) from orders;
Select sum(subtotal) from order_detail;
Unlock tables;
上面的例子在LOCK TABLES时加了“local”选项,
其作用就是在满足MyISAM表并发插入条件的情况下,允许其他用户在表尾并发插入记录
---------------------------------------------------------------------
写锁定:
1.写锁定会阻塞其他线程的读;
2.修改表结构不会阻塞其他线程的读锁定。
系统锁定的检查情况:
mysql> show status like 'table%';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| Table_locks_immediate | 112 |
| Table_locks_waited | 4 |
+-----------------------+-------+
2 rows in set (0.03 sec)
如果出现table_locks_waited 状态值高,表示有较多的资源争用情况出现。
mysql> show status like 'innodb_row_lock%';
+-------------------------------+-------+
| Variable_name | Value |
+-------------------------------+-------+
| Innodb_row_lock_current_waits | 0 |正在等待锁定的数量
| Innodb_row_lock_time | 0 |锁定总时间长度
| Innodb_row_lock_time_avg | 0 |平均锁定时间
| Innodb_row_lock_time_max | 0 |最长锁定时间
| Innodb_row_lock_waits | 0 |出现等待的总次数
+-------------------------------+-------+
5 rows in set (0.00 sec)
通过创建INNODB monitor 表来打开Innodb 的monitor功能,即时查看Innodb 的实时情况:
create table innodb_monitor(a int) engine=innodb;
然后执行:show innodb status;