mysql> show status like 'table%';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| Table_locks_immediate | 19 |
| Table_locks_waited | 0 |
+-----------------------+-------+
2 rows in set (0.00 sec)mysql
MyISAM表读操做,不会阻塞其余用户对同一表的读请求,但会阻塞对同一表的写请求;
MyISAM表的写操做,会阻塞其余用户对同一表的读请求和写请求。
MyISAM表的读操做和写操做之间,以及写操做之间是串行的sql
MyISAM表在执行SELECT语句以前,会自动给涉及到的表加读锁,在执行UPDATE、DELETE、INSERT以前,自动给涉及到的表加写锁。markdown
mysql> lock table tbl_name1 read/write;
mysql> lock tables tbl_name1 read [local], tbl_name2 write [local];并发
mysql> unlock tables;app
mysql> lock table tbl_name1 as tb1 read;
mysql> select a.id from tbl_name tb1;ide
MyISAM的读写操做是串行的,但必定程度上,也是支持查询和插入的并发进行,但不能够删除和更新。spa
0-> 不容许并发插入;
1-> 在MyISAM表没有孔洞的前提下,容许在读的同时,另外一个进程从尾部插入记录(默认)
2-> 不论有无空洞,均可以在表尾并发插入orm
mysql> optimize table tbl_name;索引
已经知道,MyISAM存储引擎的读锁和写锁是互斥的,读写操做是串行的,可是,及时读请求先到达等待队列,写请求后到达等待队列,写锁也会插入到读锁以前,由于MySQL认为写操做比读操做重要。队列
同时,这也是MyISAM表不适合有大量更新和查询操做的缘由,由于大量的更新和查询操做会占据锁等待队列,读锁会被长时间等待。
为了解决这个问题,咱们有一些参数设置来调节MyISAM的调度行为。
启动low-priority-updates,使得MyISAM 默认基于读请求以优先的权利;
下降更新请求的的优先级
mysql> set LOW_PRIORITY_UPDATES=1
指定INSERT、UPDATE、DELETE语句的LOW_PRIORITY属性,下降该语句的优先级
一种折中的方案:给系统参数max_write_locl_count设置一个合适的值,当表的读操做达到该值以后,MySQL就暂时将写请求的优先级下降。
InnoDB与MyISAM的最大不一样支出在于:一、支持事务;二、采用了行级锁。
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)
对于UPDATE、DELETE、INSERT语句,InnoDB自动给涉及数据集加排他锁;对于SELECT语句,InnoDB不会加任何锁。