主要介绍MyISAM的表锁和InnoDB的行锁
一:MyISAM的表锁
1:设置读锁:lock table t_myisam_lock read; unlock tables;//释放锁
注:不要使用别名去查询,select lock.* from t_myisam_locak as lock,会报错。解决办法就是 lock table t_myisam_lock as lock read,使用别名设置锁。
2:设置写锁:lock table t_myisam_lock write; unlock tables;//释放锁
共同点:
只要是设置了读锁或者写锁,在同一个session对其他表都不能查询和修改,在不同session对其他表都能查询和修改。
不同点:
在同一session,读锁是能查询但不能修改,写锁是能查询、能修改。
在不同session,读锁是能查询但是修改需要等待,写锁是能查询修改都需要等待。
二、innodb的行锁
1:共享锁
select * from 表名 where 条件 lock in share mode;
2:排他锁
select * from 表名 where 条件 for update;
只会锁住这一行记录,操作其他的记录直接运行。操作该条记录会等待。
注:锁住有索引的数据,会锁住查询的数据。没有索引的会锁住全部的数据。
共享锁和排他锁的区别
三、innodb的表锁
和myisam的表锁一样。不同点:开启一个新事务会释放表锁。