数据库--排他锁与共享锁

排他锁:又称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;

其它事务再进行加锁查询,则会阻塞,用普通查询可以查到数据

详细可参考:
https://www.cnblogs.com/boblogsbo/p/5602122.html

你可能感兴趣的:(MySql数据库)