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

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值