排他锁:又称X锁,若事务T对数据对象A加上X锁,则只允许T读取和修改A,其它事务都不能再对A加任何类型的锁,知道T释放A上的锁
共享锁:若事务T对数据A加共享锁S,则只允许T读取A,但不能修改A,其它事务只能再对A加S锁,直到T释放A上的S锁,这样其他事务可以读A,但在T释放A上的S锁之前不饿能够对A进行任何修改
对于查询语句:
1)加排他锁
begin;
select * from t_user where id=1 for update;//加排他锁
其它事务:
select * from t_user where id=1 for update;//阻塞
select * from t_user where id=1 lock in share mode;//阻塞
但可以直接查询;
select * from t_user where id=1;
2)加共享锁
begin;
select * from t_user where id=1 lock in share mode;//加共享锁
其它事务中只能加共享锁和不加锁
select * from t_user where id=1 lock in share mode;
或者:
select * from t_user where id=1;
3)进行update ,delete,insert 语句时 MySQL InnoDB会自动添加排他锁
begin;
update t_user set userName='Lucy' where id=1;
其它事务再进行加锁查询,则会阻塞,用普通查询可以查到数据